@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.
- package/dist/__tests__/context-cache.test.d.ts +2 -0
- package/dist/__tests__/context-cache.test.d.ts.map +1 -0
- package/dist/__tests__/context-cache.test.js +77 -0
- package/dist/__tests__/context-cache.test.js.map +1 -0
- package/dist/__tests__/context-default-factory.test.d.ts +2 -0
- package/dist/__tests__/context-default-factory.test.d.ts.map +1 -0
- package/dist/__tests__/context-default-factory.test.js +89 -0
- package/dist/__tests__/context-default-factory.test.js.map +1 -0
- package/dist/__tests__/network-egress.test.d.ts +2 -0
- package/dist/__tests__/network-egress.test.d.ts.map +1 -0
- package/dist/__tests__/network-egress.test.js +33 -0
- package/dist/__tests__/network-egress.test.js.map +1 -0
- package/dist/__tests__/shutdown.test.d.ts +2 -0
- package/dist/__tests__/shutdown.test.d.ts.map +1 -0
- package/dist/__tests__/shutdown.test.js +78 -0
- package/dist/__tests__/shutdown.test.js.map +1 -0
- package/dist/__tests__/tool-registry.test.d.ts +2 -0
- package/dist/__tests__/tool-registry.test.d.ts.map +1 -0
- package/dist/__tests__/tool-registry.test.js +21 -0
- package/dist/__tests__/tool-registry.test.js.map +1 -0
- package/dist/__tests__/zod-schema.test.d.ts +2 -0
- package/dist/__tests__/zod-schema.test.d.ts.map +1 -0
- package/dist/__tests__/zod-schema.test.js +15 -0
- package/dist/__tests__/zod-schema.test.js.map +1 -0
- package/dist/bin.d.ts +2 -0
- package/dist/bin.d.ts.map +1 -0
- package/dist/bin.js +14 -0
- package/dist/bin.js.map +1 -0
- package/dist/context.d.ts +29 -0
- package/dist/context.d.ts.map +1 -0
- package/dist/context.js +202 -0
- package/dist/context.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/server.d.ts +31 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +91 -0
- package/dist/server.js.map +1 -0
- package/dist/shutdown.d.ts +10 -0
- package/dist/shutdown.d.ts.map +1 -0
- package/dist/shutdown.js +43 -0
- package/dist/shutdown.js.map +1 -0
- package/dist/tool-registry.d.ts +31 -0
- package/dist/tool-registry.d.ts.map +1 -0
- package/dist/tool-registry.js +29 -0
- package/dist/tool-registry.js.map +1 -0
- package/dist/tools/__tests__/_fixture.d.ts +29 -0
- package/dist/tools/__tests__/_fixture.d.ts.map +1 -0
- package/dist/tools/__tests__/_fixture.js +59 -0
- package/dist/tools/__tests__/_fixture.js.map +1 -0
- package/dist/tools/__tests__/_runner.d.ts +10 -0
- package/dist/tools/__tests__/_runner.d.ts.map +1 -0
- package/dist/tools/__tests__/_runner.js +12 -0
- package/dist/tools/__tests__/_runner.js.map +1 -0
- package/dist/tools/__tests__/analyze_field.test.d.ts +2 -0
- package/dist/tools/__tests__/analyze_field.test.d.ts.map +1 -0
- package/dist/tools/__tests__/analyze_field.test.js +92 -0
- package/dist/tools/__tests__/analyze_field.test.js.map +1 -0
- package/dist/tools/__tests__/cross_layer_flow_map.test.d.ts +2 -0
- package/dist/tools/__tests__/cross_layer_flow_map.test.d.ts.map +1 -0
- package/dist/tools/__tests__/cross_layer_flow_map.test.js +111 -0
- package/dist/tools/__tests__/cross_layer_flow_map.test.js.map +1 -0
- package/dist/tools/__tests__/cross_org_diff.test.d.ts +2 -0
- package/dist/tools/__tests__/cross_org_diff.test.d.ts.map +1 -0
- package/dist/tools/__tests__/cross_org_diff.test.js +112 -0
- package/dist/tools/__tests__/cross_org_diff.test.js.map +1 -0
- package/dist/tools/__tests__/dead_code_audit.test.d.ts +2 -0
- package/dist/tools/__tests__/dead_code_audit.test.d.ts.map +1 -0
- package/dist/tools/__tests__/dead_code_audit.test.js +71 -0
- package/dist/tools/__tests__/dead_code_audit.test.js.map +1 -0
- package/dist/tools/__tests__/deployment_manifest_gen.test.d.ts +2 -0
- package/dist/tools/__tests__/deployment_manifest_gen.test.d.ts.map +1 -0
- package/dist/tools/__tests__/deployment_manifest_gen.test.js +143 -0
- package/dist/tools/__tests__/deployment_manifest_gen.test.js.map +1 -0
- package/dist/tools/__tests__/dispatcher.test.d.ts +2 -0
- package/dist/tools/__tests__/dispatcher.test.d.ts.map +1 -0
- package/dist/tools/__tests__/dispatcher.test.js +39 -0
- package/dist/tools/__tests__/dispatcher.test.js.map +1 -0
- package/dist/tools/__tests__/explain_code.test.d.ts +2 -0
- package/dist/tools/__tests__/explain_code.test.d.ts.map +1 -0
- package/dist/tools/__tests__/explain_code.test.js +88 -0
- package/dist/tools/__tests__/explain_code.test.js.map +1 -0
- package/dist/tools/__tests__/freshness_report.test.d.ts +2 -0
- package/dist/tools/__tests__/freshness_report.test.d.ts.map +1 -0
- package/dist/tools/__tests__/freshness_report.test.js +103 -0
- package/dist/tools/__tests__/freshness_report.test.js.map +1 -0
- package/dist/tools/__tests__/get_ingest_job.test.d.ts +2 -0
- package/dist/tools/__tests__/get_ingest_job.test.d.ts.map +1 -0
- package/dist/tools/__tests__/get_ingest_job.test.js +42 -0
- package/dist/tools/__tests__/get_ingest_job.test.js.map +1 -0
- package/dist/tools/__tests__/governor_risk_check.test.d.ts +2 -0
- package/dist/tools/__tests__/governor_risk_check.test.d.ts.map +1 -0
- package/dist/tools/__tests__/governor_risk_check.test.js +66 -0
- package/dist/tools/__tests__/governor_risk_check.test.js.map +1 -0
- package/dist/tools/__tests__/impact_from_git_diff.test.d.ts +2 -0
- package/dist/tools/__tests__/impact_from_git_diff.test.d.ts.map +1 -0
- package/dist/tools/__tests__/impact_from_git_diff.test.js +115 -0
- package/dist/tools/__tests__/impact_from_git_diff.test.js.map +1 -0
- package/dist/tools/__tests__/list_orgs.test.d.ts +2 -0
- package/dist/tools/__tests__/list_orgs.test.d.ts.map +1 -0
- package/dist/tools/__tests__/list_orgs.test.js +137 -0
- package/dist/tools/__tests__/list_orgs.test.js.map +1 -0
- package/dist/tools/__tests__/ping.test.d.ts +2 -0
- package/dist/tools/__tests__/ping.test.d.ts.map +1 -0
- package/dist/tools/__tests__/ping.test.js +10 -0
- package/dist/tools/__tests__/ping.test.js.map +1 -0
- package/dist/tools/__tests__/point_in_time_diff.test.d.ts +2 -0
- package/dist/tools/__tests__/point_in_time_diff.test.d.ts.map +1 -0
- package/dist/tools/__tests__/point_in_time_diff.test.js +64 -0
- package/dist/tools/__tests__/point_in_time_diff.test.js.map +1 -0
- package/dist/tools/__tests__/security_audit.test.d.ts +2 -0
- package/dist/tools/__tests__/security_audit.test.d.ts.map +1 -0
- package/dist/tools/__tests__/security_audit.test.js +99 -0
- package/dist/tools/__tests__/security_audit.test.js.map +1 -0
- package/dist/tools/__tests__/snapshot.test.d.ts +2 -0
- package/dist/tools/__tests__/snapshot.test.d.ts.map +1 -0
- package/dist/tools/__tests__/snapshot.test.js +54 -0
- package/dist/tools/__tests__/snapshot.test.js.map +1 -0
- package/dist/tools/__tests__/staleness_check.test.d.ts +2 -0
- package/dist/tools/__tests__/staleness_check.test.d.ts.map +1 -0
- package/dist/tools/__tests__/staleness_check.test.js +51 -0
- package/dist/tools/__tests__/staleness_check.test.js.map +1 -0
- package/dist/tools/__tests__/start_ingest_job.test.d.ts +2 -0
- package/dist/tools/__tests__/start_ingest_job.test.d.ts.map +1 -0
- package/dist/tools/__tests__/start_ingest_job.test.js +55 -0
- package/dist/tools/__tests__/start_ingest_job.test.js.map +1 -0
- package/dist/tools/__tests__/test_gap_intelligence.test.d.ts +2 -0
- package/dist/tools/__tests__/test_gap_intelligence.test.d.ts.map +1 -0
- package/dist/tools/__tests__/test_gap_intelligence.test.js +77 -0
- package/dist/tools/__tests__/test_gap_intelligence.test.js.map +1 -0
- package/dist/tools/__tests__/trace.test.d.ts +2 -0
- package/dist/tools/__tests__/trace.test.d.ts.map +1 -0
- package/dist/tools/__tests__/trace.test.js +130 -0
- package/dist/tools/__tests__/trace.test.js.map +1 -0
- package/dist/tools/__tests__/what_broke.test.d.ts +2 -0
- package/dist/tools/__tests__/what_broke.test.d.ts.map +1 -0
- package/dist/tools/__tests__/what_broke.test.js +60 -0
- package/dist/tools/__tests__/what_broke.test.js.map +1 -0
- package/dist/tools/__tests__/wip.test.d.ts +2 -0
- package/dist/tools/__tests__/wip.test.d.ts.map +1 -0
- package/dist/tools/__tests__/wip.test.js +173 -0
- package/dist/tools/__tests__/wip.test.js.map +1 -0
- package/dist/tools/_define.d.ts +11 -0
- package/dist/tools/_define.d.ts.map +1 -0
- package/dist/tools/_define.js +29 -0
- package/dist/tools/_define.js.map +1 -0
- package/dist/tools/_job-store.d.ts +19 -0
- package/dist/tools/_job-store.d.ts.map +1 -0
- package/dist/tools/_job-store.js +26 -0
- package/dist/tools/_job-store.js.map +1 -0
- package/dist/tools/_project-root.d.ts +20 -0
- package/dist/tools/_project-root.d.ts.map +1 -0
- package/dist/tools/_project-root.js +44 -0
- package/dist/tools/_project-root.js.map +1 -0
- package/dist/tools/analyze_field.d.ts +2 -0
- package/dist/tools/analyze_field.d.ts.map +1 -0
- package/dist/tools/analyze_field.js +77 -0
- package/dist/tools/analyze_field.js.map +1 -0
- package/dist/tools/cross_layer_flow_map.d.ts +2 -0
- package/dist/tools/cross_layer_flow_map.d.ts.map +1 -0
- package/dist/tools/cross_layer_flow_map.js +104 -0
- package/dist/tools/cross_layer_flow_map.js.map +1 -0
- package/dist/tools/cross_org_diff.d.ts +2 -0
- package/dist/tools/cross_org_diff.d.ts.map +1 -0
- package/dist/tools/cross_org_diff.js +59 -0
- package/dist/tools/cross_org_diff.js.map +1 -0
- package/dist/tools/dead_code_audit.d.ts +2 -0
- package/dist/tools/dead_code_audit.d.ts.map +1 -0
- package/dist/tools/dead_code_audit.js +67 -0
- package/dist/tools/dead_code_audit.js.map +1 -0
- package/dist/tools/deployment_manifest_gen.d.ts +2 -0
- package/dist/tools/deployment_manifest_gen.d.ts.map +1 -0
- package/dist/tools/deployment_manifest_gen.js +43 -0
- package/dist/tools/deployment_manifest_gen.js.map +1 -0
- package/dist/tools/explain_code.d.ts +2 -0
- package/dist/tools/explain_code.d.ts.map +1 -0
- package/dist/tools/explain_code.js +109 -0
- package/dist/tools/explain_code.js.map +1 -0
- package/dist/tools/freshness_report.d.ts +2 -0
- package/dist/tools/freshness_report.d.ts.map +1 -0
- package/dist/tools/freshness_report.js +66 -0
- package/dist/tools/freshness_report.js.map +1 -0
- package/dist/tools/get_ingest_job.d.ts +2 -0
- package/dist/tools/get_ingest_job.d.ts.map +1 -0
- package/dist/tools/get_ingest_job.js +24 -0
- package/dist/tools/get_ingest_job.js.map +1 -0
- package/dist/tools/governor_risk_check.d.ts +2 -0
- package/dist/tools/governor_risk_check.d.ts.map +1 -0
- package/dist/tools/governor_risk_check.js +50 -0
- package/dist/tools/governor_risk_check.js.map +1 -0
- package/dist/tools/impact_from_git_diff.d.ts +2 -0
- package/dist/tools/impact_from_git_diff.d.ts.map +1 -0
- package/dist/tools/impact_from_git_diff.js +67 -0
- package/dist/tools/impact_from_git_diff.js.map +1 -0
- package/dist/tools/index.d.ts +27 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +28 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/list_orgs.d.ts +30 -0
- package/dist/tools/list_orgs.d.ts.map +1 -0
- package/dist/tools/list_orgs.js +302 -0
- package/dist/tools/list_orgs.js.map +1 -0
- package/dist/tools/ping.d.ts +3 -0
- package/dist/tools/ping.d.ts.map +1 -0
- package/dist/tools/ping.js +23 -0
- package/dist/tools/ping.js.map +1 -0
- package/dist/tools/point_in_time_diff.d.ts +2 -0
- package/dist/tools/point_in_time_diff.d.ts.map +1 -0
- package/dist/tools/point_in_time_diff.js +37 -0
- package/dist/tools/point_in_time_diff.js.map +1 -0
- package/dist/tools/security_audit.d.ts +2 -0
- package/dist/tools/security_audit.d.ts.map +1 -0
- package/dist/tools/security_audit.js +56 -0
- package/dist/tools/security_audit.js.map +1 -0
- package/dist/tools/snapshot_create.d.ts +2 -0
- package/dist/tools/snapshot_create.d.ts.map +1 -0
- package/dist/tools/snapshot_create.js +24 -0
- package/dist/tools/snapshot_create.js.map +1 -0
- package/dist/tools/snapshot_list.d.ts +2 -0
- package/dist/tools/snapshot_list.d.ts.map +1 -0
- package/dist/tools/snapshot_list.js +22 -0
- package/dist/tools/snapshot_list.js.map +1 -0
- package/dist/tools/staleness_check.d.ts +2 -0
- package/dist/tools/staleness_check.d.ts.map +1 -0
- package/dist/tools/staleness_check.js +50 -0
- package/dist/tools/staleness_check.js.map +1 -0
- package/dist/tools/start_ingest_job.d.ts +2 -0
- package/dist/tools/start_ingest_job.d.ts.map +1 -0
- package/dist/tools/start_ingest_job.js +83 -0
- package/dist/tools/start_ingest_job.js.map +1 -0
- package/dist/tools/test_gap_intelligence_from_git_diff.d.ts +2 -0
- package/dist/tools/test_gap_intelligence_from_git_diff.d.ts.map +1 -0
- package/dist/tools/test_gap_intelligence_from_git_diff.js +50 -0
- package/dist/tools/test_gap_intelligence_from_git_diff.js.map +1 -0
- package/dist/tools/trace_downstream.d.ts +2 -0
- package/dist/tools/trace_downstream.d.ts.map +1 -0
- package/dist/tools/trace_downstream.js +43 -0
- package/dist/tools/trace_downstream.js.map +1 -0
- package/dist/tools/trace_upstream.d.ts +2 -0
- package/dist/tools/trace_upstream.d.ts.map +1 -0
- package/dist/tools/trace_upstream.js +43 -0
- package/dist/tools/trace_upstream.js.map +1 -0
- package/dist/tools/what_broke.d.ts +2 -0
- package/dist/tools/what_broke.d.ts.map +1 -0
- package/dist/tools/what_broke.js +86 -0
- package/dist/tools/what_broke.js.map +1 -0
- package/dist/tools/wip_diff.d.ts +2 -0
- package/dist/tools/wip_diff.d.ts.map +1 -0
- package/dist/tools/wip_diff.js +55 -0
- package/dist/tools/wip_diff.js.map +1 -0
- package/dist/tools/wip_impact.d.ts +2 -0
- package/dist/tools/wip_impact.d.ts.map +1 -0
- package/dist/tools/wip_impact.js +55 -0
- package/dist/tools/wip_impact.js.map +1 -0
- package/dist/tools/wip_test_gap.d.ts +2 -0
- package/dist/tools/wip_test_gap.d.ts.map +1 -0
- package/dist/tools/wip_test_gap.js +50 -0
- package/dist/tools/wip_test_gap.js.map +1 -0
- 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":"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"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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"}
|