@ryanstark24/sfgraph-server 1.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 (261) hide show
  1. package/dist/__tests__/context-cache.test.d.ts +2 -0
  2. package/dist/__tests__/context-cache.test.d.ts.map +1 -0
  3. package/dist/__tests__/context-cache.test.js +77 -0
  4. package/dist/__tests__/context-cache.test.js.map +1 -0
  5. package/dist/__tests__/context-default-factory.test.d.ts +2 -0
  6. package/dist/__tests__/context-default-factory.test.d.ts.map +1 -0
  7. package/dist/__tests__/context-default-factory.test.js +89 -0
  8. package/dist/__tests__/context-default-factory.test.js.map +1 -0
  9. package/dist/__tests__/network-egress.test.d.ts +2 -0
  10. package/dist/__tests__/network-egress.test.d.ts.map +1 -0
  11. package/dist/__tests__/network-egress.test.js +33 -0
  12. package/dist/__tests__/network-egress.test.js.map +1 -0
  13. package/dist/__tests__/shutdown.test.d.ts +2 -0
  14. package/dist/__tests__/shutdown.test.d.ts.map +1 -0
  15. package/dist/__tests__/shutdown.test.js +78 -0
  16. package/dist/__tests__/shutdown.test.js.map +1 -0
  17. package/dist/__tests__/tool-registry.test.d.ts +2 -0
  18. package/dist/__tests__/tool-registry.test.d.ts.map +1 -0
  19. package/dist/__tests__/tool-registry.test.js +21 -0
  20. package/dist/__tests__/tool-registry.test.js.map +1 -0
  21. package/dist/__tests__/zod-schema.test.d.ts +2 -0
  22. package/dist/__tests__/zod-schema.test.d.ts.map +1 -0
  23. package/dist/__tests__/zod-schema.test.js +15 -0
  24. package/dist/__tests__/zod-schema.test.js.map +1 -0
  25. package/dist/bin.d.ts +2 -0
  26. package/dist/bin.d.ts.map +1 -0
  27. package/dist/bin.js +14 -0
  28. package/dist/bin.js.map +1 -0
  29. package/dist/context.d.ts +29 -0
  30. package/dist/context.d.ts.map +1 -0
  31. package/dist/context.js +202 -0
  32. package/dist/context.js.map +1 -0
  33. package/dist/index.d.ts +8 -0
  34. package/dist/index.d.ts.map +1 -0
  35. package/dist/index.js +6 -0
  36. package/dist/index.js.map +1 -0
  37. package/dist/server.d.ts +31 -0
  38. package/dist/server.d.ts.map +1 -0
  39. package/dist/server.js +91 -0
  40. package/dist/server.js.map +1 -0
  41. package/dist/shutdown.d.ts +10 -0
  42. package/dist/shutdown.d.ts.map +1 -0
  43. package/dist/shutdown.js +43 -0
  44. package/dist/shutdown.js.map +1 -0
  45. package/dist/tool-registry.d.ts +31 -0
  46. package/dist/tool-registry.d.ts.map +1 -0
  47. package/dist/tool-registry.js +29 -0
  48. package/dist/tool-registry.js.map +1 -0
  49. package/dist/tools/__tests__/_fixture.d.ts +29 -0
  50. package/dist/tools/__tests__/_fixture.d.ts.map +1 -0
  51. package/dist/tools/__tests__/_fixture.js +59 -0
  52. package/dist/tools/__tests__/_fixture.js.map +1 -0
  53. package/dist/tools/__tests__/_runner.d.ts +10 -0
  54. package/dist/tools/__tests__/_runner.d.ts.map +1 -0
  55. package/dist/tools/__tests__/_runner.js +12 -0
  56. package/dist/tools/__tests__/_runner.js.map +1 -0
  57. package/dist/tools/__tests__/analyze_field.test.d.ts +2 -0
  58. package/dist/tools/__tests__/analyze_field.test.d.ts.map +1 -0
  59. package/dist/tools/__tests__/analyze_field.test.js +92 -0
  60. package/dist/tools/__tests__/analyze_field.test.js.map +1 -0
  61. package/dist/tools/__tests__/cross_layer_flow_map.test.d.ts +2 -0
  62. package/dist/tools/__tests__/cross_layer_flow_map.test.d.ts.map +1 -0
  63. package/dist/tools/__tests__/cross_layer_flow_map.test.js +111 -0
  64. package/dist/tools/__tests__/cross_layer_flow_map.test.js.map +1 -0
  65. package/dist/tools/__tests__/cross_org_diff.test.d.ts +2 -0
  66. package/dist/tools/__tests__/cross_org_diff.test.d.ts.map +1 -0
  67. package/dist/tools/__tests__/cross_org_diff.test.js +112 -0
  68. package/dist/tools/__tests__/cross_org_diff.test.js.map +1 -0
  69. package/dist/tools/__tests__/dead_code_audit.test.d.ts +2 -0
  70. package/dist/tools/__tests__/dead_code_audit.test.d.ts.map +1 -0
  71. package/dist/tools/__tests__/dead_code_audit.test.js +71 -0
  72. package/dist/tools/__tests__/dead_code_audit.test.js.map +1 -0
  73. package/dist/tools/__tests__/deployment_manifest_gen.test.d.ts +2 -0
  74. package/dist/tools/__tests__/deployment_manifest_gen.test.d.ts.map +1 -0
  75. package/dist/tools/__tests__/deployment_manifest_gen.test.js +143 -0
  76. package/dist/tools/__tests__/deployment_manifest_gen.test.js.map +1 -0
  77. package/dist/tools/__tests__/dispatcher.test.d.ts +2 -0
  78. package/dist/tools/__tests__/dispatcher.test.d.ts.map +1 -0
  79. package/dist/tools/__tests__/dispatcher.test.js +39 -0
  80. package/dist/tools/__tests__/dispatcher.test.js.map +1 -0
  81. package/dist/tools/__tests__/explain_code.test.d.ts +2 -0
  82. package/dist/tools/__tests__/explain_code.test.d.ts.map +1 -0
  83. package/dist/tools/__tests__/explain_code.test.js +88 -0
  84. package/dist/tools/__tests__/explain_code.test.js.map +1 -0
  85. package/dist/tools/__tests__/freshness_report.test.d.ts +2 -0
  86. package/dist/tools/__tests__/freshness_report.test.d.ts.map +1 -0
  87. package/dist/tools/__tests__/freshness_report.test.js +103 -0
  88. package/dist/tools/__tests__/freshness_report.test.js.map +1 -0
  89. package/dist/tools/__tests__/get_ingest_job.test.d.ts +2 -0
  90. package/dist/tools/__tests__/get_ingest_job.test.d.ts.map +1 -0
  91. package/dist/tools/__tests__/get_ingest_job.test.js +42 -0
  92. package/dist/tools/__tests__/get_ingest_job.test.js.map +1 -0
  93. package/dist/tools/__tests__/governor_risk_check.test.d.ts +2 -0
  94. package/dist/tools/__tests__/governor_risk_check.test.d.ts.map +1 -0
  95. package/dist/tools/__tests__/governor_risk_check.test.js +66 -0
  96. package/dist/tools/__tests__/governor_risk_check.test.js.map +1 -0
  97. package/dist/tools/__tests__/impact_from_git_diff.test.d.ts +2 -0
  98. package/dist/tools/__tests__/impact_from_git_diff.test.d.ts.map +1 -0
  99. package/dist/tools/__tests__/impact_from_git_diff.test.js +115 -0
  100. package/dist/tools/__tests__/impact_from_git_diff.test.js.map +1 -0
  101. package/dist/tools/__tests__/list_orgs.test.d.ts +2 -0
  102. package/dist/tools/__tests__/list_orgs.test.d.ts.map +1 -0
  103. package/dist/tools/__tests__/list_orgs.test.js +137 -0
  104. package/dist/tools/__tests__/list_orgs.test.js.map +1 -0
  105. package/dist/tools/__tests__/ping.test.d.ts +2 -0
  106. package/dist/tools/__tests__/ping.test.d.ts.map +1 -0
  107. package/dist/tools/__tests__/ping.test.js +10 -0
  108. package/dist/tools/__tests__/ping.test.js.map +1 -0
  109. package/dist/tools/__tests__/point_in_time_diff.test.d.ts +2 -0
  110. package/dist/tools/__tests__/point_in_time_diff.test.d.ts.map +1 -0
  111. package/dist/tools/__tests__/point_in_time_diff.test.js +64 -0
  112. package/dist/tools/__tests__/point_in_time_diff.test.js.map +1 -0
  113. package/dist/tools/__tests__/security_audit.test.d.ts +2 -0
  114. package/dist/tools/__tests__/security_audit.test.d.ts.map +1 -0
  115. package/dist/tools/__tests__/security_audit.test.js +99 -0
  116. package/dist/tools/__tests__/security_audit.test.js.map +1 -0
  117. package/dist/tools/__tests__/snapshot.test.d.ts +2 -0
  118. package/dist/tools/__tests__/snapshot.test.d.ts.map +1 -0
  119. package/dist/tools/__tests__/snapshot.test.js +54 -0
  120. package/dist/tools/__tests__/snapshot.test.js.map +1 -0
  121. package/dist/tools/__tests__/staleness_check.test.d.ts +2 -0
  122. package/dist/tools/__tests__/staleness_check.test.d.ts.map +1 -0
  123. package/dist/tools/__tests__/staleness_check.test.js +51 -0
  124. package/dist/tools/__tests__/staleness_check.test.js.map +1 -0
  125. package/dist/tools/__tests__/start_ingest_job.test.d.ts +2 -0
  126. package/dist/tools/__tests__/start_ingest_job.test.d.ts.map +1 -0
  127. package/dist/tools/__tests__/start_ingest_job.test.js +55 -0
  128. package/dist/tools/__tests__/start_ingest_job.test.js.map +1 -0
  129. package/dist/tools/__tests__/test_gap_intelligence.test.d.ts +2 -0
  130. package/dist/tools/__tests__/test_gap_intelligence.test.d.ts.map +1 -0
  131. package/dist/tools/__tests__/test_gap_intelligence.test.js +77 -0
  132. package/dist/tools/__tests__/test_gap_intelligence.test.js.map +1 -0
  133. package/dist/tools/__tests__/trace.test.d.ts +2 -0
  134. package/dist/tools/__tests__/trace.test.d.ts.map +1 -0
  135. package/dist/tools/__tests__/trace.test.js +130 -0
  136. package/dist/tools/__tests__/trace.test.js.map +1 -0
  137. package/dist/tools/__tests__/what_broke.test.d.ts +2 -0
  138. package/dist/tools/__tests__/what_broke.test.d.ts.map +1 -0
  139. package/dist/tools/__tests__/what_broke.test.js +60 -0
  140. package/dist/tools/__tests__/what_broke.test.js.map +1 -0
  141. package/dist/tools/__tests__/wip.test.d.ts +2 -0
  142. package/dist/tools/__tests__/wip.test.d.ts.map +1 -0
  143. package/dist/tools/__tests__/wip.test.js +173 -0
  144. package/dist/tools/__tests__/wip.test.js.map +1 -0
  145. package/dist/tools/_define.d.ts +11 -0
  146. package/dist/tools/_define.d.ts.map +1 -0
  147. package/dist/tools/_define.js +29 -0
  148. package/dist/tools/_define.js.map +1 -0
  149. package/dist/tools/_job-store.d.ts +19 -0
  150. package/dist/tools/_job-store.d.ts.map +1 -0
  151. package/dist/tools/_job-store.js +26 -0
  152. package/dist/tools/_job-store.js.map +1 -0
  153. package/dist/tools/_project-root.d.ts +20 -0
  154. package/dist/tools/_project-root.d.ts.map +1 -0
  155. package/dist/tools/_project-root.js +44 -0
  156. package/dist/tools/_project-root.js.map +1 -0
  157. package/dist/tools/analyze_field.d.ts +2 -0
  158. package/dist/tools/analyze_field.d.ts.map +1 -0
  159. package/dist/tools/analyze_field.js +77 -0
  160. package/dist/tools/analyze_field.js.map +1 -0
  161. package/dist/tools/cross_layer_flow_map.d.ts +2 -0
  162. package/dist/tools/cross_layer_flow_map.d.ts.map +1 -0
  163. package/dist/tools/cross_layer_flow_map.js +104 -0
  164. package/dist/tools/cross_layer_flow_map.js.map +1 -0
  165. package/dist/tools/cross_org_diff.d.ts +2 -0
  166. package/dist/tools/cross_org_diff.d.ts.map +1 -0
  167. package/dist/tools/cross_org_diff.js +59 -0
  168. package/dist/tools/cross_org_diff.js.map +1 -0
  169. package/dist/tools/dead_code_audit.d.ts +2 -0
  170. package/dist/tools/dead_code_audit.d.ts.map +1 -0
  171. package/dist/tools/dead_code_audit.js +67 -0
  172. package/dist/tools/dead_code_audit.js.map +1 -0
  173. package/dist/tools/deployment_manifest_gen.d.ts +2 -0
  174. package/dist/tools/deployment_manifest_gen.d.ts.map +1 -0
  175. package/dist/tools/deployment_manifest_gen.js +43 -0
  176. package/dist/tools/deployment_manifest_gen.js.map +1 -0
  177. package/dist/tools/explain_code.d.ts +2 -0
  178. package/dist/tools/explain_code.d.ts.map +1 -0
  179. package/dist/tools/explain_code.js +109 -0
  180. package/dist/tools/explain_code.js.map +1 -0
  181. package/dist/tools/freshness_report.d.ts +2 -0
  182. package/dist/tools/freshness_report.d.ts.map +1 -0
  183. package/dist/tools/freshness_report.js +66 -0
  184. package/dist/tools/freshness_report.js.map +1 -0
  185. package/dist/tools/get_ingest_job.d.ts +2 -0
  186. package/dist/tools/get_ingest_job.d.ts.map +1 -0
  187. package/dist/tools/get_ingest_job.js +24 -0
  188. package/dist/tools/get_ingest_job.js.map +1 -0
  189. package/dist/tools/governor_risk_check.d.ts +2 -0
  190. package/dist/tools/governor_risk_check.d.ts.map +1 -0
  191. package/dist/tools/governor_risk_check.js +50 -0
  192. package/dist/tools/governor_risk_check.js.map +1 -0
  193. package/dist/tools/impact_from_git_diff.d.ts +2 -0
  194. package/dist/tools/impact_from_git_diff.d.ts.map +1 -0
  195. package/dist/tools/impact_from_git_diff.js +67 -0
  196. package/dist/tools/impact_from_git_diff.js.map +1 -0
  197. package/dist/tools/index.d.ts +27 -0
  198. package/dist/tools/index.d.ts.map +1 -0
  199. package/dist/tools/index.js +28 -0
  200. package/dist/tools/index.js.map +1 -0
  201. package/dist/tools/list_orgs.d.ts +30 -0
  202. package/dist/tools/list_orgs.d.ts.map +1 -0
  203. package/dist/tools/list_orgs.js +302 -0
  204. package/dist/tools/list_orgs.js.map +1 -0
  205. package/dist/tools/ping.d.ts +3 -0
  206. package/dist/tools/ping.d.ts.map +1 -0
  207. package/dist/tools/ping.js +23 -0
  208. package/dist/tools/ping.js.map +1 -0
  209. package/dist/tools/point_in_time_diff.d.ts +2 -0
  210. package/dist/tools/point_in_time_diff.d.ts.map +1 -0
  211. package/dist/tools/point_in_time_diff.js +37 -0
  212. package/dist/tools/point_in_time_diff.js.map +1 -0
  213. package/dist/tools/security_audit.d.ts +2 -0
  214. package/dist/tools/security_audit.d.ts.map +1 -0
  215. package/dist/tools/security_audit.js +56 -0
  216. package/dist/tools/security_audit.js.map +1 -0
  217. package/dist/tools/snapshot_create.d.ts +2 -0
  218. package/dist/tools/snapshot_create.d.ts.map +1 -0
  219. package/dist/tools/snapshot_create.js +24 -0
  220. package/dist/tools/snapshot_create.js.map +1 -0
  221. package/dist/tools/snapshot_list.d.ts +2 -0
  222. package/dist/tools/snapshot_list.d.ts.map +1 -0
  223. package/dist/tools/snapshot_list.js +22 -0
  224. package/dist/tools/snapshot_list.js.map +1 -0
  225. package/dist/tools/staleness_check.d.ts +2 -0
  226. package/dist/tools/staleness_check.d.ts.map +1 -0
  227. package/dist/tools/staleness_check.js +50 -0
  228. package/dist/tools/staleness_check.js.map +1 -0
  229. package/dist/tools/start_ingest_job.d.ts +2 -0
  230. package/dist/tools/start_ingest_job.d.ts.map +1 -0
  231. package/dist/tools/start_ingest_job.js +83 -0
  232. package/dist/tools/start_ingest_job.js.map +1 -0
  233. package/dist/tools/test_gap_intelligence_from_git_diff.d.ts +2 -0
  234. package/dist/tools/test_gap_intelligence_from_git_diff.d.ts.map +1 -0
  235. package/dist/tools/test_gap_intelligence_from_git_diff.js +50 -0
  236. package/dist/tools/test_gap_intelligence_from_git_diff.js.map +1 -0
  237. package/dist/tools/trace_downstream.d.ts +2 -0
  238. package/dist/tools/trace_downstream.d.ts.map +1 -0
  239. package/dist/tools/trace_downstream.js +43 -0
  240. package/dist/tools/trace_downstream.js.map +1 -0
  241. package/dist/tools/trace_upstream.d.ts +2 -0
  242. package/dist/tools/trace_upstream.d.ts.map +1 -0
  243. package/dist/tools/trace_upstream.js +43 -0
  244. package/dist/tools/trace_upstream.js.map +1 -0
  245. package/dist/tools/what_broke.d.ts +2 -0
  246. package/dist/tools/what_broke.d.ts.map +1 -0
  247. package/dist/tools/what_broke.js +86 -0
  248. package/dist/tools/what_broke.js.map +1 -0
  249. package/dist/tools/wip_diff.d.ts +2 -0
  250. package/dist/tools/wip_diff.d.ts.map +1 -0
  251. package/dist/tools/wip_diff.js +55 -0
  252. package/dist/tools/wip_diff.js.map +1 -0
  253. package/dist/tools/wip_impact.d.ts +2 -0
  254. package/dist/tools/wip_impact.d.ts.map +1 -0
  255. package/dist/tools/wip_impact.js +55 -0
  256. package/dist/tools/wip_impact.js.map +1 -0
  257. package/dist/tools/wip_test_gap.d.ts +2 -0
  258. package/dist/tools/wip_test_gap.d.ts.map +1 -0
  259. package/dist/tools/wip_test_gap.js +50 -0
  260. package/dist/tools/wip_test_gap.js.map +1 -0
  261. package/package.json +61 -0
@@ -0,0 +1,66 @@
1
+ import { analyze } from "@ryanstark24/sfgraph-core";
2
+ import { METADATA_CATEGORY } from "@ryanstark24/sfgraph-core";
3
+ import { getToolContext } from "../context.js";
4
+ import { defineTool, z } from "./_define.js";
5
+ const inputSchema = z.object({
6
+ org: z.string().min(1),
7
+ bucket: z.enum(["stale", "hot", "dead", "current"]).optional(),
8
+ });
9
+ const SCAN_LABELS = [
10
+ METADATA_CATEGORY.APEX_CLASS,
11
+ METADATA_CATEGORY.LWC,
12
+ METADATA_CATEGORY.FLOW,
13
+ METADATA_CATEGORY.OBJECT,
14
+ ];
15
+ const FRESHNESS_PER_LABEL_CAP = 5000;
16
+ defineTool({
17
+ name: "freshness_report",
18
+ description: "USE THIS for any 'what is stale' / 'old metadata' / 'when was X last touched' question. Buckets every Salesforce node by freshness (dead / stale / current / hot). Cleanup prioritization.",
19
+ inputSchema,
20
+ async execute(input) {
21
+ const ctx = await getToolContext({ orgId: input.org });
22
+ const now = Date.now();
23
+ const buckets = {
24
+ hot: [],
25
+ current: [],
26
+ stale: [],
27
+ dead: [],
28
+ };
29
+ let truncated = false;
30
+ for (const lbl of SCAN_LABELS) {
31
+ const rows = ctx.graphStore.listNodesByLabel(ctx.orgId, lbl, FRESHNESS_PER_LABEL_CAP);
32
+ if (rows.length >= FRESHNESS_PER_LABEL_CAP)
33
+ truncated = true;
34
+ for (const n of rows) {
35
+ const s = analyze.freshnessScore(n, now);
36
+ const b = analyze.freshnessBucket(s);
37
+ (buckets[b] ?? []).push({ qualifiedName: n.qualifiedName, score: s, label: n.label });
38
+ }
39
+ }
40
+ for (const k of Object.keys(buckets)) {
41
+ const arr = buckets[k] ?? [];
42
+ arr.sort((a, b) => a.score - b.score);
43
+ buckets[k] = arr.slice(0, 20);
44
+ }
45
+ const filter = input.bucket;
46
+ const md = (filter ? [filter] : Object.keys(buckets))
47
+ .map((b) => {
48
+ const rows = (buckets[b] ?? [])
49
+ .map((r) => `| \`${r.qualifiedName}\` | ${r.label} | ${r.score.toFixed(2)} |`)
50
+ .join("\n");
51
+ return `### ${b}\n\n| qname | label | score |\n|---|---|---|\n${rows || "_empty_"}`;
52
+ })
53
+ .join("\n\n");
54
+ const truncationNote = truncated
55
+ ? ` — results capped at ${FRESHNESS_PER_LABEL_CAP}/label; narrow scope or paginate`
56
+ : "";
57
+ return {
58
+ summary: `freshness report ${filter ?? "all buckets"}${truncationNote}`,
59
+ markdown: truncated
60
+ ? `${md}\n\n> _Note: at least one label hit the ${FRESHNESS_PER_LABEL_CAP}-row cap. Results are incomplete._`
61
+ : md,
62
+ data: { buckets, truncated },
63
+ };
64
+ },
65
+ });
66
+ //# sourceMappingURL=freshness_report.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"freshness_report.js","sourceRoot":"","sources":["../../src/tools/freshness_report.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,cAAc,CAAC;AAE7C,MAAM,WAAW,GAAG,CAAC,CAAC,MAAM,CAAC;IAC3B,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACtB,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE;CAC/D,CAAC,CAAC;AAEH,MAAM,WAAW,GAAG;IAClB,iBAAiB,CAAC,UAAU;IAC5B,iBAAiB,CAAC,GAAG;IACrB,iBAAiB,CAAC,IAAI;IACtB,iBAAiB,CAAC,MAAM;CACzB,CAAC;AAEF,MAAM,uBAAuB,GAAG,IAAI,CAAC;AAErC,UAAU,CAAC;IACT,IAAI,EAAE,kBAAkB;IACxB,WAAW,EACT,4LAA4L;IAC9L,WAAW;IACX,KAAK,CAAC,OAAO,CAAC,KAAK;QACjB,MAAM,GAAG,GAAG,MAAM,cAAc,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QACvD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,OAAO,GAGT;YACF,GAAG,EAAE,EAAE;YACP,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,EAAE;SACT,CAAC;QACF,IAAI,SAAS,GAAG,KAAK,CAAC;QACtB,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE,uBAAuB,CAAC,CAAC;YACtF,IAAI,IAAI,CAAC,MAAM,IAAI,uBAAuB;gBAAE,SAAS,GAAG,IAAI,CAAC;YAC7D,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;gBACrB,MAAM,CAAC,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBACzC,MAAM,CAAC,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;gBACrC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;YACxF,CAAC;QACH,CAAC;QACD,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;YACrC,MAAM,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAC7B,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;YACtC,OAAO,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QAChC,CAAC;QACD,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,MAAM,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aAClD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACT,MAAM,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;iBAC5B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,aAAa,QAAQ,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;iBAC7E,IAAI,CAAC,IAAI,CAAC,CAAC;YACd,OAAO,OAAO,CAAC,iDAAiD,IAAI,IAAI,SAAS,EAAE,CAAC;QACtF,CAAC,CAAC;aACD,IAAI,CAAC,MAAM,CAAC,CAAC;QAChB,MAAM,cAAc,GAAG,SAAS;YAC9B,CAAC,CAAC,wBAAwB,uBAAuB,kCAAkC;YACnF,CAAC,CAAC,EAAE,CAAC;QACP,OAAO;YACL,OAAO,EAAE,oBAAoB,MAAM,IAAI,aAAa,GAAG,cAAc,EAAE;YACvE,QAAQ,EAAE,SAAS;gBACjB,CAAC,CAAC,GAAG,EAAE,2CAA2C,uBAAuB,oCAAoC;gBAC7G,CAAC,CAAC,EAAE;YACN,IAAI,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE;SAC7B,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=get_ingest_job.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get_ingest_job.d.ts","sourceRoot":"","sources":["../../src/tools/get_ingest_job.ts"],"names":[],"mappings":""}
@@ -0,0 +1,24 @@
1
+ import { defineTool, z } from "./_define.js";
2
+ import { getJob } from "./_job-store.js";
3
+ const inputSchema = z.object({ job_id: z.string().min(1) });
4
+ defineTool({
5
+ name: "get_ingest_job",
6
+ description: "Fetch state of an ingest job by id.",
7
+ inputSchema,
8
+ async execute(input) {
9
+ const job = getJob(input.job_id);
10
+ if (!job) {
11
+ return {
12
+ summary: `unknown job ${input.job_id}`,
13
+ markdown: `> No job with id \`${input.job_id}\``,
14
+ data: { found: false },
15
+ };
16
+ }
17
+ return {
18
+ summary: `job ${job.job_id} is ${job.state}`,
19
+ markdown: `Job \`${job.job_id}\` — state **${job.state}** — progress ${job.progress.processed}/${job.progress.total}`,
20
+ data: job,
21
+ };
22
+ },
23
+ });
24
+ //# sourceMappingURL=get_ingest_job.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get_ingest_job.js","sourceRoot":"","sources":["../../src/tools/get_ingest_job.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC,MAAM,WAAW,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAE5D,UAAU,CAAC;IACT,IAAI,EAAE,gBAAgB;IACtB,WAAW,EAAE,qCAAqC;IAClD,WAAW;IACX,KAAK,CAAC,OAAO,CAAC,KAAK;QACjB,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACjC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO;gBACL,OAAO,EAAE,eAAe,KAAK,CAAC,MAAM,EAAE;gBACtC,QAAQ,EAAE,sBAAsB,KAAK,CAAC,MAAM,IAAI;gBAChD,IAAI,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE;aACvB,CAAC;QACJ,CAAC;QACD,OAAO;YACL,OAAO,EAAE,OAAO,GAAG,CAAC,MAAM,OAAO,GAAG,CAAC,KAAK,EAAE;YAC5C,QAAQ,EAAE,SAAS,GAAG,CAAC,MAAM,gBAAgB,GAAG,CAAC,KAAK,iBAAiB,GAAG,CAAC,QAAQ,CAAC,SAAS,IAAI,GAAG,CAAC,QAAQ,CAAC,KAAK,EAAE;YACrH,IAAI,EAAE,GAAG;SACV,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=governor_risk_check.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"governor_risk_check.d.ts","sourceRoot":"","sources":["../../src/tools/governor_risk_check.ts"],"names":[],"mappings":""}
@@ -0,0 +1,50 @@
1
+ import { analyze } from "@ryanstark24/sfgraph-core";
2
+ import { getToolContext } from "../context.js";
3
+ import { defineTool, z } from "./_define.js";
4
+ const inputSchema = z.object({ org: z.string().min(1) });
5
+ function readCachedRisks(db, orgId) {
6
+ try {
7
+ const d = db;
8
+ const rows = d
9
+ .prepare("SELECT qualified_name, risk_type, evidence FROM _sfgraph_governor_risks WHERE org_id = ?")
10
+ .all(orgId);
11
+ if (!rows || rows.length === 0)
12
+ return null;
13
+ return rows.map((r) => ({
14
+ qualifiedName: r.qualified_name,
15
+ risk: r.risk_type,
16
+ evidence: r.evidence ?? "",
17
+ }));
18
+ }
19
+ catch {
20
+ return null;
21
+ }
22
+ }
23
+ defineTool({
24
+ name: "governor_risk_check",
25
+ description: "USE THIS for any 'SOQL in loop' / 'will this scale' / 'performance review' / 'governor limits' question about Salesforce Apex. Returns Apex methods/triggers with SOQL-in-loop, DML-in-loop, unbounded queries, missing trigger bulkification — with line + snippet.",
26
+ inputSchema,
27
+ async execute(input) {
28
+ const ctx = await getToolContext({ orgId: input.org });
29
+ const cached = ctx.db ? readCachedRisks(ctx.db, ctx.orgId) : null;
30
+ const risks = cached ?? analyze.findGovernorRisks(ctx.graphStore, ctx.orgId);
31
+ if (risks.length === 0) {
32
+ return {
33
+ summary: "no risks detected",
34
+ markdown: "_no governor risks surfaced_",
35
+ data: { risks: [], cached: cached !== null },
36
+ };
37
+ }
38
+ const md = [
39
+ "| qname | risk | evidence |",
40
+ "|---|---|---|",
41
+ ...risks.map((r) => `| \`${r.qualifiedName}\` | ${r.risk} | ${r.evidence} |`),
42
+ ].join("\n");
43
+ return {
44
+ summary: `${risks.length} governor risks${cached ? " (cached)" : ""}`,
45
+ markdown: md,
46
+ data: { risks, cached: cached !== null },
47
+ };
48
+ },
49
+ });
50
+ //# sourceMappingURL=governor_risk_check.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"governor_risk_check.js","sourceRoot":"","sources":["../../src/tools/governor_risk_check.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,cAAc,CAAC;AAE7C,MAAM,WAAW,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAQzD,SAAS,eAAe,CAAC,EAAW,EAAE,KAAa;IACjD,IAAI,CAAC;QACH,MAAM,CAAC,GAAG,EAQT,CAAC;QACF,MAAM,IAAI,GAAG,CAAC;aACX,OAAO,CACN,0FAA0F,CAC3F;aACA,GAAG,CAAC,KAAK,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC;QAC5C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtB,aAAa,EAAE,CAAC,CAAC,cAAc;YAC/B,IAAI,EAAE,CAAC,CAAC,SAAS;YACjB,QAAQ,EAAE,CAAC,CAAC,QAAQ,IAAI,EAAE;SAC3B,CAAC,CAAC,CAAC;IACN,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,UAAU,CAAC;IACT,IAAI,EAAE,qBAAqB;IAC3B,WAAW,EACT,sQAAsQ;IACxQ,WAAW;IACX,KAAK,CAAC,OAAO,CAAC,KAAK;QACjB,MAAM,GAAG,GAAG,MAAM,cAAc,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QACvD,MAAM,MAAM,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAClE,MAAM,KAAK,GAAG,MAAM,IAAI,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;QAC7E,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvB,OAAO;gBACL,OAAO,EAAE,mBAAmB;gBAC5B,QAAQ,EAAE,8BAA8B;gBACxC,IAAI,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,EAAE;aAC7C,CAAC;QACJ,CAAC;QACD,MAAM,EAAE,GAAG;YACT,6BAA6B;YAC7B,eAAe;YACf,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,aAAa,QAAQ,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,QAAQ,IAAI,CAAC;SAC9E,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACb,OAAO;YACL,OAAO,EAAE,GAAG,KAAK,CAAC,MAAM,kBAAkB,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,EAAE;YACrE,QAAQ,EAAE,EAAE;YACZ,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,EAAE;SACzC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=impact_from_git_diff.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"impact_from_git_diff.d.ts","sourceRoot":"","sources":["../../src/tools/impact_from_git_diff.ts"],"names":[],"mappings":""}
@@ -0,0 +1,67 @@
1
+ import { analyze, render } from "@ryanstark24/sfgraph-core";
2
+ import { asQualifiedName } from "@ryanstark24/sfgraph-shared";
3
+ import { getToolContext } from "../context.js";
4
+ import { defineTool, z } from "./_define.js";
5
+ const inputSchema = z.object({
6
+ org: z.string().min(1),
7
+ diff: z.string().min(1),
8
+ depth: z.number().int().min(1).max(5).default(3),
9
+ });
10
+ defineTool({
11
+ name: "impact_from_git_diff",
12
+ description: "USE THIS for any 'what does this PR break' / 'impact of these changes' / 'blast radius before merge' question about a Salesforce repo. Maps changed file paths to graph nodes via N-hop reverse BFS. Returns every Apex / LWC / Flow / field that depends on the changes.",
13
+ inputSchema,
14
+ async execute(input) {
15
+ const ctx = await getToolContext({ orgId: input.org });
16
+ const files = analyze.parseUnifiedDiff(input.diff);
17
+ const seedQnames = [];
18
+ for (const f of files) {
19
+ const qn = analyze.pathToQualifiedName(f.path);
20
+ if (qn)
21
+ seedQnames.push(qn);
22
+ }
23
+ const nodeMap = new Map();
24
+ const edges = [];
25
+ let truncated = false;
26
+ for (const qn of seedQnames) {
27
+ const qname = asQualifiedName(qn);
28
+ const node = ctx.graphStore.getNode(ctx.orgId, qname);
29
+ nodeMap.set(qn, { qualifiedName: qn, label: node?.label ?? "Changed" });
30
+ const up = analyze.findDependents(ctx.graphStore, ctx.orgId, qname, input.depth);
31
+ const down = analyze.findDependencies(ctx.graphStore, ctx.orgId, qname, input.depth);
32
+ if (up.truncated || down.truncated)
33
+ truncated = true;
34
+ for (const n of [...up.nodes, ...down.nodes]) {
35
+ nodeMap.set(n.qualifiedName, { qualifiedName: n.qualifiedName, label: n.label });
36
+ }
37
+ for (const e of [...up.edges, ...down.edges]) {
38
+ edges.push({
39
+ srcQualifiedName: e.srcQualifiedName,
40
+ dstQualifiedName: e.dstQualifiedName,
41
+ relType: e.relType,
42
+ });
43
+ }
44
+ }
45
+ const mermaid = render.renderDependencyGraph({
46
+ nodes: Array.from(nodeMap.values()),
47
+ edges,
48
+ title: "impact_from_git_diff",
49
+ });
50
+ const mdLines = [
51
+ `Seed: ${seedQnames.length} files. Total impacted: ${nodeMap.size}.`,
52
+ "",
53
+ "```mermaid",
54
+ mermaid,
55
+ "```",
56
+ ];
57
+ if (truncated) {
58
+ mdLines.push("", "_truncated_ — one or more seeds hit the traversal node cap. Lower `depth` or split the diff.");
59
+ }
60
+ return {
61
+ summary: `${nodeMap.size} nodes impacted from ${seedQnames.length} changed files${truncated ? " (truncated)" : ""}`,
62
+ markdown: mdLines.join("\n"),
63
+ data: { seedQnames, impacted: Array.from(nodeMap.keys()), truncated },
64
+ };
65
+ },
66
+ });
67
+ //# sourceMappingURL=impact_from_git_diff.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"impact_from_git_diff.js","sourceRoot":"","sources":["../../src/tools/impact_from_git_diff.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import "./ping.js";
2
+ import "./start_ingest_job.js";
3
+ import "./get_ingest_job.js";
4
+ import "./snapshot_create.js";
5
+ import "./snapshot_list.js";
6
+ import "./point_in_time_diff.js";
7
+ import "./what_broke.js";
8
+ import "./freshness_report.js";
9
+ import "./analyze_field.js";
10
+ import "./impact_from_git_diff.js";
11
+ import "./test_gap_intelligence_from_git_diff.js";
12
+ import "./cross_layer_flow_map.js";
13
+ import "./trace_upstream.js";
14
+ import "./trace_downstream.js";
15
+ import "./cross_org_diff.js";
16
+ import "./governor_risk_check.js";
17
+ import "./dead_code_audit.js";
18
+ import "./security_audit.js";
19
+ import "./deployment_manifest_gen.js";
20
+ import "./wip_impact.js";
21
+ import "./wip_diff.js";
22
+ import "./wip_test_gap.js";
23
+ import "./list_orgs.js";
24
+ import "./staleness_check.js";
25
+ import "./explain_code.js";
26
+ export { defaultRegistry } from "../tool-registry.js";
27
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AACA,OAAO,WAAW,CAAC;AACnB,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,sBAAsB,CAAC;AAC9B,OAAO,oBAAoB,CAAC;AAC5B,OAAO,yBAAyB,CAAC;AACjC,OAAO,iBAAiB,CAAC;AACzB,OAAO,uBAAuB,CAAC;AAC/B,OAAO,oBAAoB,CAAC;AAC5B,OAAO,2BAA2B,CAAC;AACnC,OAAO,0CAA0C,CAAC;AAClD,OAAO,2BAA2B,CAAC;AACnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,0BAA0B,CAAC;AAClC,OAAO,sBAAsB,CAAC;AAC9B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,8BAA8B,CAAC;AACtC,OAAO,iBAAiB,CAAC;AACzB,OAAO,eAAe,CAAC;AACvB,OAAO,mBAAmB,CAAC;AAC3B,OAAO,gBAAgB,CAAC;AACxB,OAAO,sBAAsB,CAAC;AAC9B,OAAO,mBAAmB,CAAC;AAE3B,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,28 @@
1
+ // Side-effect imports — each module registers its tool on the default registry.
2
+ import "./ping.js";
3
+ import "./start_ingest_job.js";
4
+ import "./get_ingest_job.js";
5
+ import "./snapshot_create.js";
6
+ import "./snapshot_list.js";
7
+ import "./point_in_time_diff.js";
8
+ import "./what_broke.js";
9
+ import "./freshness_report.js";
10
+ import "./analyze_field.js";
11
+ import "./impact_from_git_diff.js";
12
+ import "./test_gap_intelligence_from_git_diff.js";
13
+ import "./cross_layer_flow_map.js";
14
+ import "./trace_upstream.js";
15
+ import "./trace_downstream.js";
16
+ import "./cross_org_diff.js";
17
+ import "./governor_risk_check.js";
18
+ import "./dead_code_audit.js";
19
+ import "./security_audit.js";
20
+ import "./deployment_manifest_gen.js";
21
+ import "./wip_impact.js";
22
+ import "./wip_diff.js";
23
+ import "./wip_test_gap.js";
24
+ import "./list_orgs.js";
25
+ import "./staleness_check.js";
26
+ import "./explain_code.js";
27
+ export { defaultRegistry } from "../tool-registry.js";
28
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA,gFAAgF;AAChF,OAAO,WAAW,CAAC;AACnB,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,sBAAsB,CAAC;AAC9B,OAAO,oBAAoB,CAAC;AAC5B,OAAO,yBAAyB,CAAC;AACjC,OAAO,iBAAiB,CAAC;AACzB,OAAO,uBAAuB,CAAC;AAC/B,OAAO,oBAAoB,CAAC;AAC5B,OAAO,2BAA2B,CAAC;AACnC,OAAO,0CAA0C,CAAC;AAClD,OAAO,2BAA2B,CAAC;AACnC,OAAO,qBAAqB,CAAC;AAC7B,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,0BAA0B,CAAC;AAClC,OAAO,sBAAsB,CAAC;AAC9B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,8BAA8B,CAAC;AACtC,OAAO,iBAAiB,CAAC;AACzB,OAAO,eAAe,CAAC;AACvB,OAAO,mBAAmB,CAAC;AAC3B,OAAO,gBAAgB,CAAC;AACxB,OAAO,sBAAsB,CAAC;AAC9B,OAAO,mBAAmB,CAAC;AAE3B,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,30 @@
1
+ interface AuthorizationRow {
2
+ alias?: string | null;
3
+ username?: string | null;
4
+ orgId?: string | null;
5
+ instanceUrl?: string | null;
6
+ }
7
+ interface ListOrgsDeps {
8
+ loadSfCore?: () => Promise<{
9
+ AuthInfo: {
10
+ listAllAuthorizations: () => Promise<AuthorizationRow[]>;
11
+ };
12
+ /** Optional — when present, used to fill in `alias` for orgs whose
13
+ * listAllAuthorizations entry has alias=null even though the user has
14
+ * the alias bound in `sf` CLI. */
15
+ aliasByUsername?: Map<string, string>;
16
+ ConfigAggregator?: unknown;
17
+ }>;
18
+ resolveDefaultOrgAlias?: () => Promise<string | null>;
19
+ dataDir?: string;
20
+ openDb?: (p: string) => {
21
+ prepare: (s: string) => {
22
+ get: (a: string) => unknown;
23
+ };
24
+ close: () => void;
25
+ } | null;
26
+ }
27
+ /** Test seam — replace the SF core loader / DB opener / paths. */
28
+ export declare function __setListOrgsDeps(d: ListOrgsDeps | null): void;
29
+ export {};
30
+ //# sourceMappingURL=list_orgs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list_orgs.d.ts","sourceRoot":"","sources":["../../src/tools/list_orgs.ts"],"names":[],"mappings":"AAcA,UAAU,gBAAgB;IACxB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,UAAU,YAAY;IACpB,UAAU,CAAC,EAAE,MAAM,OAAO,CAAC;QACzB,QAAQ,EAAE;YACR,qBAAqB,EAAE,MAAM,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;SAC1D,CAAC;QACF;;2CAEmC;QACnC,eAAe,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACtC,gBAAgB,CAAC,EAAE,OAAO,CAAC;KAC5B,CAAC,CAAC;IACH,sBAAsB,CAAC,EAAE,MAAM,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IACtD,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,CACP,CAAC,EAAE,MAAM,KACN;QAAE,OAAO,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK;YAAE,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,OAAO,CAAA;SAAE,CAAC;QAAC,KAAK,EAAE,MAAM,IAAI,CAAA;KAAE,GAAG,IAAI,CAAC;CAC5F;AAID,kEAAkE;AAClE,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,YAAY,GAAG,IAAI,GAAG,IAAI,CAE9D"}