@tmhs/homelab-mcp 0.7.0 → 0.9.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/README.md +10 -1
- package/dist/index.js +15 -1
- package/dist/index.js.map +1 -1
- package/dist/tools/adguardFilters.d.ts.map +1 -1
- package/dist/tools/adguardFilters.js +3 -2
- package/dist/tools/adguardFilters.js.map +1 -1
- package/dist/tools/adguardQueryLog.d.ts.map +1 -1
- package/dist/tools/adguardQueryLog.js +3 -1
- package/dist/tools/adguardQueryLog.js.map +1 -1
- package/dist/tools/adguardStats.d.ts.map +1 -1
- package/dist/tools/adguardStats.js +3 -2
- package/dist/tools/adguardStats.js.map +1 -1
- package/dist/tools/alertList.d.ts.map +1 -1
- package/dist/tools/alertList.js +3 -1
- package/dist/tools/alertList.js.map +1 -1
- package/dist/tools/aptHistory.d.ts.map +1 -1
- package/dist/tools/aptHistory.js +3 -1
- package/dist/tools/aptHistory.js.map +1 -1
- package/dist/tools/aptUpdate.d.ts.map +1 -1
- package/dist/tools/aptUpdate.js +3 -1
- package/dist/tools/aptUpdate.js.map +1 -1
- package/dist/tools/aptUpgradable.d.ts.map +1 -1
- package/dist/tools/aptUpgradable.js +4 -3
- package/dist/tools/aptUpgradable.js.map +1 -1
- package/dist/tools/backupDiff.d.ts.map +1 -1
- package/dist/tools/backupDiff.js +3 -1
- package/dist/tools/backupDiff.js.map +1 -1
- package/dist/tools/backupList.d.ts.map +1 -1
- package/dist/tools/backupList.js +3 -1
- package/dist/tools/backupList.js.map +1 -1
- package/dist/tools/backupRestore.d.ts.map +1 -1
- package/dist/tools/backupRestore.js +3 -1
- package/dist/tools/backupRestore.js.map +1 -1
- package/dist/tools/backupRun.d.ts.map +1 -1
- package/dist/tools/backupRun.js +3 -1
- package/dist/tools/backupRun.js.map +1 -1
- package/dist/tools/backupStatus.d.ts.map +1 -1
- package/dist/tools/backupStatus.js +3 -1
- package/dist/tools/backupStatus.js.map +1 -1
- package/dist/tools/certCheck.d.ts +3 -0
- package/dist/tools/certCheck.d.ts.map +1 -0
- package/dist/tools/certCheck.js +31 -0
- package/dist/tools/certCheck.js.map +1 -0
- package/dist/tools/certList.d.ts +3 -0
- package/dist/tools/certList.d.ts.map +1 -0
- package/dist/tools/certList.js +40 -0
- package/dist/tools/certList.js.map +1 -0
- package/dist/tools/certRenew.d.ts +3 -0
- package/dist/tools/certRenew.d.ts.map +1 -0
- package/dist/tools/certRenew.js +47 -0
- package/dist/tools/certRenew.js.map +1 -0
- package/dist/tools/composeDown.d.ts.map +1 -1
- package/dist/tools/composeDown.js +3 -1
- package/dist/tools/composeDown.js.map +1 -1
- package/dist/tools/composePs.d.ts.map +1 -1
- package/dist/tools/composePs.js +3 -2
- package/dist/tools/composePs.js.map +1 -1
- package/dist/tools/composePull.d.ts.map +1 -1
- package/dist/tools/composePull.js +3 -1
- package/dist/tools/composePull.js.map +1 -1
- package/dist/tools/composeUp.d.ts.map +1 -1
- package/dist/tools/composeUp.js +3 -1
- package/dist/tools/composeUp.js.map +1 -1
- package/dist/tools/containerScan.d.ts.map +1 -1
- package/dist/tools/containerScan.js +4 -2
- package/dist/tools/containerScan.js.map +1 -1
- package/dist/tools/diskUsage.d.ts.map +1 -1
- package/dist/tools/diskUsage.js +3 -1
- package/dist/tools/diskUsage.js.map +1 -1
- package/dist/tools/fail2banStatus.d.ts.map +1 -1
- package/dist/tools/fail2banStatus.js +3 -1
- package/dist/tools/fail2banStatus.js.map +1 -1
- package/dist/tools/grafanaSnapshot.d.ts.map +1 -1
- package/dist/tools/grafanaSnapshot.js +3 -1
- package/dist/tools/grafanaSnapshot.js.map +1 -1
- package/dist/tools/inventorySync.d.ts +3 -0
- package/dist/tools/inventorySync.d.ts.map +1 -0
- package/dist/tools/inventorySync.js +36 -0
- package/dist/tools/inventorySync.js.map +1 -0
- package/dist/tools/journalLogs.d.ts.map +1 -1
- package/dist/tools/journalLogs.js +3 -1
- package/dist/tools/journalLogs.js.map +1 -1
- package/dist/tools/kernelInfo.d.ts.map +1 -1
- package/dist/tools/kernelInfo.js +4 -3
- package/dist/tools/kernelInfo.js.map +1 -1
- package/dist/tools/logSearch.d.ts.map +1 -1
- package/dist/tools/logSearch.js +3 -1
- package/dist/tools/logSearch.js.map +1 -1
- package/dist/tools/networkInfo.d.ts.map +1 -1
- package/dist/tools/networkInfo.js +3 -2
- package/dist/tools/networkInfo.js.map +1 -1
- package/dist/tools/nodeExec.d.ts +3 -0
- package/dist/tools/nodeExec.d.ts.map +1 -0
- package/dist/tools/nodeExec.js +34 -0
- package/dist/tools/nodeExec.js.map +1 -0
- package/dist/tools/nodeList.d.ts +3 -0
- package/dist/tools/nodeList.d.ts.map +1 -0
- package/dist/tools/nodeList.js +24 -0
- package/dist/tools/nodeList.js.map +1 -0
- package/dist/tools/nodeStatus.d.ts +3 -0
- package/dist/tools/nodeStatus.d.ts.map +1 -0
- package/dist/tools/nodeStatus.js +30 -0
- package/dist/tools/nodeStatus.js.map +1 -0
- package/dist/tools/npmCerts.d.ts.map +1 -1
- package/dist/tools/npmCerts.js +6 -5
- package/dist/tools/npmCerts.js.map +1 -1
- package/dist/tools/npmProxyHosts.d.ts.map +1 -1
- package/dist/tools/npmProxyHosts.js +6 -5
- package/dist/tools/npmProxyHosts.js.map +1 -1
- package/dist/tools/ntfySend.d.ts.map +1 -1
- package/dist/tools/ntfySend.js +3 -1
- package/dist/tools/ntfySend.js.map +1 -1
- package/dist/tools/ntfyTopics.d.ts.map +1 -1
- package/dist/tools/ntfyTopics.js +3 -1
- package/dist/tools/ntfyTopics.js.map +1 -1
- package/dist/tools/openPorts.d.ts.map +1 -1
- package/dist/tools/openPorts.js +3 -2
- package/dist/tools/openPorts.js.map +1 -1
- package/dist/tools/piReboot.d.ts.map +1 -1
- package/dist/tools/piReboot.js +5 -3
- package/dist/tools/piReboot.js.map +1 -1
- package/dist/tools/piStatus.d.ts.map +1 -1
- package/dist/tools/piStatus.js +3 -2
- package/dist/tools/piStatus.js.map +1 -1
- package/dist/tools/prometheusQuery.d.ts.map +1 -1
- package/dist/tools/prometheusQuery.js +3 -1
- package/dist/tools/prometheusQuery.js.map +1 -1
- package/dist/tools/serviceHealth.d.ts.map +1 -1
- package/dist/tools/serviceHealth.js +4 -2
- package/dist/tools/serviceHealth.js.map +1 -1
- package/dist/tools/serviceLogs.d.ts.map +1 -1
- package/dist/tools/serviceLogs.js +3 -1
- package/dist/tools/serviceLogs.js.map +1 -1
- package/dist/tools/serviceRestart.d.ts.map +1 -1
- package/dist/tools/serviceRestart.js +4 -2
- package/dist/tools/serviceRestart.js.map +1 -1
- package/dist/tools/speedtestResults.d.ts.map +1 -1
- package/dist/tools/speedtestResults.js +3 -1
- package/dist/tools/speedtestResults.js.map +1 -1
- package/dist/tools/sshTest.d.ts.map +1 -1
- package/dist/tools/sshTest.js +3 -2
- package/dist/tools/sshTest.js.map +1 -1
- package/dist/tools/systemdServices.d.ts.map +1 -1
- package/dist/tools/systemdServices.js +3 -1
- package/dist/tools/systemdServices.js.map +1 -1
- package/dist/tools/ufwStatus.d.ts.map +1 -1
- package/dist/tools/ufwStatus.js +3 -2
- package/dist/tools/ufwStatus.js.map +1 -1
- package/dist/tools/uptimeKumaStatus.d.ts.map +1 -1
- package/dist/tools/uptimeKumaStatus.js +3 -2
- package/dist/tools/uptimeKumaStatus.js.map +1 -1
- package/dist/tools/volumeBackup.d.ts.map +1 -1
- package/dist/tools/volumeBackup.js +3 -1
- package/dist/tools/volumeBackup.js.map +1 -1
- package/dist/utils/node-param.d.ts +5 -0
- package/dist/utils/node-param.d.ts.map +1 -0
- package/dist/utils/node-param.js +8 -0
- package/dist/utils/node-param.js.map +1 -0
- package/dist/utils/ssh-api.d.ts +12 -1
- package/dist/utils/ssh-api.d.ts.map +1 -1
- package/dist/utils/ssh-api.js +50 -7
- package/dist/utils/ssh-api.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"certList.js","sourceRoot":"","sources":["../../src/tools/certList.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAiB,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC;AAErC,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,kBAAkB,EAClB,wEAAwE,EACxE,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,MAAM,QAAQ,GAAa,EAAE,CAAC;QAE9B,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,MAAM,OAAO,CAChC,0EAA0E,EAC1E,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,IAAI,YAAY,CAAC,IAAI,EAAE,KAAK,WAAW,EAAE,CAAC;gBACxC,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,gCAAgC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBACjF,QAAQ,CAAC,IAAI,CAAC,gCAAgC,GAAG,aAAa,CAAC,CAAC;YAClE,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;YAC7D,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,QAAQ,CAAC,IAAI,CAAC,wDAAwD,CAAC,CAAC;QAC1E,CAAC;QAED,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB;gBAC1C,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,EAAE,CAAC;gBAC5C,CAAC,CAAC,EAAE,CAAC;YACP,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,mBAAmB,CAAC;YACnE,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,oBAAoB,IAAI,UAAU,CAAC;YAChE,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;YAEtE,MAAM,WAAW,GAAG,MAAM,OAAO,CAC/B,uDAAuD;gBACrD,OAAO,OAAO,uBAAuB,OAAO,cAAc,EAC5D,IAAI,CAAC,IAAI,CACV,CAAC;YACF,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC;YAE5C,MAAM,WAAW,GAAG,MAAM,OAAO,CAC/B,sCAAsC,KAAK,IAAI;gBAC7C,qBAAqB,OAAO,0BAA0B,EACxD,IAAI,CAAC,IAAI,CACV,CAAC;YACF,QAAQ,CAAC,IAAI,CAAC,8CAA8C,GAAG,WAAW,CAAC,CAAC;QAC9E,CAAC;QAAC,MAAM,CAAC;YACP,QAAQ,CAAC,IAAI,CAAC,sGAAsG,CAAC,CAAC;QACxH,CAAC;QAED,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;IAC7E,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"certRenew.d.ts","sourceRoot":"","sources":["../../src/tools/certRenew.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAezE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CA0ChD"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
4
|
+
const inputSchema = {
|
|
5
|
+
...nodeParam,
|
|
6
|
+
domain: z
|
|
7
|
+
.string()
|
|
8
|
+
.optional()
|
|
9
|
+
.describe("Specific certificate name to renew. Renews all eligible certificates if omitted"),
|
|
10
|
+
confirm: z
|
|
11
|
+
.boolean()
|
|
12
|
+
.describe("Safety gate -- must be true to proceed with renewal"),
|
|
13
|
+
};
|
|
14
|
+
export function register(server) {
|
|
15
|
+
server.tool("homelab_certRenew", "Trigger Let's Encrypt certificate renewal via certbot", inputSchema, async (args) => {
|
|
16
|
+
if (!args.confirm) {
|
|
17
|
+
return {
|
|
18
|
+
content: [{
|
|
19
|
+
type: "text",
|
|
20
|
+
text: "Renewal aborted -- set confirm=true to proceed.",
|
|
21
|
+
}],
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
const certbotCheck = await execSSH("command -v certbot >/dev/null 2>&1 && echo 'installed' || echo 'missing'", args.node);
|
|
26
|
+
if (certbotCheck.trim() === "missing") {
|
|
27
|
+
return {
|
|
28
|
+
content: [{
|
|
29
|
+
type: "text",
|
|
30
|
+
text: "certbot is not installed on the Pi. Install it with:\n\n" +
|
|
31
|
+
"sudo apt install -y certbot\n\n" +
|
|
32
|
+
"If using Nginx Proxy Manager, certificates are managed through NPM's UI instead.",
|
|
33
|
+
}],
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
const cmd = args.domain
|
|
37
|
+
? `sudo certbot renew --cert-name '${args.domain}' --force-renewal 2>&1`
|
|
38
|
+
: "sudo certbot renew 2>&1";
|
|
39
|
+
const output = await execSSH(cmd, args.node);
|
|
40
|
+
return { content: [{ type: "text", text: output }] };
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
return errorResponse(error);
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=certRenew.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"certRenew.js","sourceRoot":"","sources":["../../src/tools/certRenew.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,MAAM,EAAE,CAAC;SACN,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,iFAAiF,CAAC;IAC9F,OAAO,EAAE,CAAC;SACP,OAAO,EAAE;SACT,QAAQ,CAAC,qDAAqD,CAAC;CACnE,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,mBAAmB,EACnB,uDAAuD,EACvD,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO;gBACL,OAAO,EAAE,CAAC;wBACR,IAAI,EAAE,MAAe;wBACrB,IAAI,EAAE,iDAAiD;qBACxD,CAAC;aACH,CAAC;QACJ,CAAC;QAED,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,MAAM,OAAO,CAChC,0EAA0E,EAC1E,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,IAAI,YAAY,CAAC,IAAI,EAAE,KAAK,SAAS,EAAE,CAAC;gBACtC,OAAO;oBACL,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,MAAe;4BACrB,IAAI,EAAE,0DAA0D;gCAC9D,iCAAiC;gCACjC,kFAAkF;yBACrF,CAAC;iBACH,CAAC;YACJ,CAAC;YAED,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM;gBACrB,CAAC,CAAC,mCAAmC,IAAI,CAAC,MAAM,wBAAwB;gBACxE,CAAC,CAAC,yBAAyB,CAAC;YAC9B,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composeDown.d.ts","sourceRoot":"","sources":["../../src/tools/composeDown.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"composeDown.d.ts","sourceRoot":"","sources":["../../src/tools/composeDown.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAmBzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CA0BhD"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const COMPOSE_DIR = process.env.HOMELAB_COMPOSE_DIR || "/opt/homelab/docker";
|
|
4
5
|
const inputSchema = {
|
|
6
|
+
...nodeParam,
|
|
5
7
|
stacks: z
|
|
6
8
|
.array(z.string())
|
|
7
9
|
.optional()
|
|
@@ -23,7 +25,7 @@ export function register(server) {
|
|
|
23
25
|
files += " -f compose.monitoring.yml -f compose.network.yml -f compose.apps.yml -f compose.security.yml -f compose.storage.yml -f compose.tools.yml";
|
|
24
26
|
}
|
|
25
27
|
const volFlag = args.removeVolumes ? " -v" : "";
|
|
26
|
-
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose ${files} down${volFlag} 2>&1
|
|
28
|
+
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose ${files} down${volFlag} 2>&1`, args.node);
|
|
27
29
|
return { content: [{ type: "text", text: output }] };
|
|
28
30
|
}
|
|
29
31
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composeDown.js","sourceRoot":"","sources":["../../src/tools/composeDown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"composeDown.js","sourceRoot":"","sources":["../../src/tools/composeDown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,qBAAqB,CAAC;AAE7E,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,MAAM,EAAE,CAAC;SACN,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;SACjB,QAAQ,EAAE;SACV,QAAQ,CAAC,+CAA+C,CAAC;IAC5D,aAAa,EAAE,CAAC;SACb,OAAO,EAAE;SACT,QAAQ,EAAE;SACV,OAAO,CAAC,KAAK,CAAC;SACd,QAAQ,CAAC,oDAAoD,CAAC;CAClE,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,qBAAqB,EACrB,sCAAsC,EACtC,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,IAAI,KAAK,GAAG,qBAAqB,CAAC;YAClC,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,KAAK,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,KAAK,IAAI,2IAA2I,CAAC;YACvJ,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;YAChD,MAAM,MAAM,GAAG,MAAM,OAAO,CAC1B,MAAM,WAAW,sBAAsB,KAAK,QAAQ,OAAO,OAAO,EAClE,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composePs.d.ts","sourceRoot":"","sources":["../../src/tools/composePs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"composePs.d.ts","sourceRoot":"","sources":["../../src/tools/composePs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAMzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAuBhD"}
|
package/dist/tools/composePs.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
1
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
2
3
|
const COMPOSE_DIR = process.env.HOMELAB_COMPOSE_DIR || "/opt/homelab/docker";
|
|
3
4
|
export function register(server) {
|
|
4
|
-
server.tool("homelab_composePs", "List running Docker Compose containers on the Pi", {}, async () => {
|
|
5
|
+
server.tool("homelab_composePs", "List running Docker Compose containers on the Pi", { ...nodeParam }, async (args) => {
|
|
5
6
|
try {
|
|
6
|
-
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose -f compose.base.yml -f compose.monitoring.yml -f compose.network.yml -f compose.apps.yml -f compose.security.yml -f compose.storage.yml -f compose.tools.yml ps --format "table {{.Name}}\\t{{.Status}}\\t{{.Ports}}" 2>&1
|
|
7
|
+
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose -f compose.base.yml -f compose.monitoring.yml -f compose.network.yml -f compose.apps.yml -f compose.security.yml -f compose.storage.yml -f compose.tools.yml ps --format "table {{.Name}}\\t{{.Status}}\\t{{.Ports}}" 2>&1`, args.node);
|
|
7
8
|
return {
|
|
8
9
|
content: [{
|
|
9
10
|
type: "text",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composePs.js","sourceRoot":"","sources":["../../src/tools/composePs.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE7D,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,qBAAqB,CAAC;AAE7E,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,mBAAmB,EACnB,kDAAkD,EAClD,EAAE,
|
|
1
|
+
{"version":3,"file":"composePs.js","sourceRoot":"","sources":["../../src/tools/composePs.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE7D,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,qBAAqB,CAAC;AAE7E,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,mBAAmB,EACnB,kDAAkD,EAClD,EAAE,GAAG,SAAS,EAAE,EAChB,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAC1B,MAAM,WAAW,+OAA+O,EAChQ,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,OAAO;gBACL,OAAO,EAAE,CAAC;wBACR,IAAI,EAAE,MAAe;wBACrB,IAAI,EAAE,MAAM,IAAI,gCAAgC;qBACjD,CAAC;aACH,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composePull.d.ts","sourceRoot":"","sources":["../../src/tools/composePull.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"composePull.d.ts","sourceRoot":"","sources":["../../src/tools/composePull.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAczE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAyBhD"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const COMPOSE_DIR = process.env.HOMELAB_COMPOSE_DIR || "/opt/homelab/docker";
|
|
4
5
|
const inputSchema = {
|
|
6
|
+
...nodeParam,
|
|
5
7
|
stacks: z
|
|
6
8
|
.array(z.string())
|
|
7
9
|
.optional()
|
|
@@ -17,7 +19,7 @@ export function register(server) {
|
|
|
17
19
|
else {
|
|
18
20
|
files += " -f compose.monitoring.yml -f compose.network.yml -f compose.apps.yml -f compose.security.yml -f compose.storage.yml -f compose.tools.yml";
|
|
19
21
|
}
|
|
20
|
-
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose ${files} pull 2>&1
|
|
22
|
+
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose ${files} pull 2>&1`, args.node);
|
|
21
23
|
return { content: [{ type: "text", text: output }] };
|
|
22
24
|
}
|
|
23
25
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composePull.js","sourceRoot":"","sources":["../../src/tools/composePull.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"composePull.js","sourceRoot":"","sources":["../../src/tools/composePull.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,qBAAqB,CAAC;AAE7E,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,MAAM,EAAE,CAAC;SACN,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;SACjB,QAAQ,EAAE;SACV,QAAQ,CAAC,0DAA0D,CAAC;CACxE,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,qBAAqB,EACrB,wDAAwD,EACxD,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,IAAI,KAAK,GAAG,qBAAqB,CAAC;YAClC,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,KAAK,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,KAAK,IAAI,2IAA2I,CAAC;YACvJ,CAAC;YAED,MAAM,MAAM,GAAG,MAAM,OAAO,CAC1B,MAAM,WAAW,sBAAsB,KAAK,YAAY,EACxD,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composeUp.d.ts","sourceRoot":"","sources":["../../src/tools/composeUp.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"composeUp.d.ts","sourceRoot":"","sources":["../../src/tools/composeUp.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAczE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAyBhD"}
|
package/dist/tools/composeUp.js
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const COMPOSE_DIR = process.env.HOMELAB_COMPOSE_DIR || "/opt/homelab/docker";
|
|
4
5
|
const inputSchema = {
|
|
6
|
+
...nodeParam,
|
|
5
7
|
stacks: z
|
|
6
8
|
.array(z.string())
|
|
7
9
|
.optional()
|
|
@@ -17,7 +19,7 @@ export function register(server) {
|
|
|
17
19
|
else {
|
|
18
20
|
files += " -f compose.monitoring.yml -f compose.network.yml -f compose.apps.yml -f compose.security.yml -f compose.storage.yml -f compose.tools.yml";
|
|
19
21
|
}
|
|
20
|
-
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose ${files} up -d --remove-orphans 2>&1
|
|
22
|
+
const output = await execSSH(`cd ${COMPOSE_DIR} && docker compose ${files} up -d --remove-orphans 2>&1`, args.node);
|
|
21
23
|
return { content: [{ type: "text", text: output }] };
|
|
22
24
|
}
|
|
23
25
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"composeUp.js","sourceRoot":"","sources":["../../src/tools/composeUp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"composeUp.js","sourceRoot":"","sources":["../../src/tools/composeUp.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,qBAAqB,CAAC;AAE7E,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,MAAM,EAAE,CAAC;SACN,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;SACjB,QAAQ,EAAE;SACV,QAAQ,CAAC,kFAAkF,CAAC;CAChG,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,mBAAmB,EACnB,uCAAuC,EACvC,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,IAAI,KAAK,GAAG,qBAAqB,CAAC;YAClC,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,KAAK,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,KAAK,IAAI,2IAA2I,CAAC;YACvJ,CAAC;YAED,MAAM,MAAM,GAAG,MAAM,OAAO,CAC1B,MAAM,WAAW,sBAAsB,KAAK,8BAA8B,EAC1E,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"containerScan.d.ts","sourceRoot":"","sources":["../../src/tools/containerScan.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"containerScan.d.ts","sourceRoot":"","sources":["../../src/tools/containerScan.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAYzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAmChD"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const inputSchema = {
|
|
5
|
+
...nodeParam,
|
|
4
6
|
image: z
|
|
5
7
|
.string()
|
|
6
8
|
.optional()
|
|
@@ -9,7 +11,7 @@ const inputSchema = {
|
|
|
9
11
|
export function register(server) {
|
|
10
12
|
server.tool("homelab_containerScan", "Scan running container images for HIGH/CRITICAL vulnerabilities using Trivy", inputSchema, async (args) => {
|
|
11
13
|
try {
|
|
12
|
-
const trivyCheck = await execSSH("command -v trivy >/dev/null 2>&1 && echo 'installed' || echo 'missing'");
|
|
14
|
+
const trivyCheck = await execSSH("command -v trivy >/dev/null 2>&1 && echo 'installed' || echo 'missing'", args.node);
|
|
13
15
|
if (trivyCheck.trim() === "missing") {
|
|
14
16
|
return {
|
|
15
17
|
content: [{
|
|
@@ -25,7 +27,7 @@ export function register(server) {
|
|
|
25
27
|
const cmd = args.image
|
|
26
28
|
? `trivy image --severity HIGH,CRITICAL --format table '${args.image}' 2>&1`
|
|
27
29
|
: "docker ps --format '{{.Image}}' | sort -u | while read img; do echo \"=== $img ===\"; trivy image --severity HIGH,CRITICAL --format table \"$img\" 2>&1; echo; done";
|
|
28
|
-
const output = await execSSH(cmd);
|
|
30
|
+
const output = await execSSH(cmd, args.node);
|
|
29
31
|
return { content: [{ type: "text", text: output }] };
|
|
30
32
|
}
|
|
31
33
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"containerScan.js","sourceRoot":"","sources":["../../src/tools/containerScan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"containerScan.js","sourceRoot":"","sources":["../../src/tools/containerScan.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,KAAK,EAAE,CAAC;SACL,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,uEAAuE,CAAC;CACrF,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,uBAAuB,EACvB,6EAA6E,EAC7E,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,MAAM,OAAO,CAC9B,wEAAwE,EACxE,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,IAAI,UAAU,CAAC,IAAI,EAAE,KAAK,SAAS,EAAE,CAAC;gBACpC,OAAO;oBACL,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,MAAe;4BACrB,IAAI,EAAE,wDAAwD;gCAC5D,iDAAiD;gCACjD,4IAA4I;gCAC5I,iKAAiK;gCACjK,8CAA8C;yBACjD,CAAC;iBACH,CAAC;YACJ,CAAC;YAED,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK;gBACpB,CAAC,CAAC,wDAAwD,IAAI,CAAC,KAAK,QAAQ;gBAC5E,CAAC,CAAC,qKAAqK,CAAC;YAC1K,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"diskUsage.d.ts","sourceRoot":"","sources":["../../src/tools/diskUsage.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"diskUsage.d.ts","sourceRoot":"","sources":["../../src/tools/diskUsage.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAoBzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAwBhD"}
|
package/dist/tools/diskUsage.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const inputSchema = {
|
|
5
|
+
...nodeParam,
|
|
4
6
|
path: z
|
|
5
7
|
.string()
|
|
6
8
|
.optional()
|
|
@@ -26,7 +28,7 @@ export function register(server) {
|
|
|
26
28
|
'echo ""',
|
|
27
29
|
'echo "=== Docker Disk Usage ==="',
|
|
28
30
|
"docker system df 2>/dev/null || echo 'Docker not available'",
|
|
29
|
-
].join(" && "));
|
|
31
|
+
].join(" && "), args.node);
|
|
30
32
|
return { content: [{ type: "text", text: output }] };
|
|
31
33
|
}
|
|
32
34
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"diskUsage.js","sourceRoot":"","sources":["../../src/tools/diskUsage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"diskUsage.js","sourceRoot":"","sources":["../../src/tools/diskUsage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,IAAI,EAAE,CAAC;SACJ,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,OAAO,CAAC,GAAG,CAAC;SACZ,QAAQ,CAAC,2CAA2C,CAAC;IACxD,KAAK,EAAE,CAAC;SACL,MAAM,EAAE;SACR,GAAG,EAAE;SACL,QAAQ,EAAE;SACV,QAAQ,EAAE;SACV,OAAO,CAAC,CAAC,CAAC;SACV,QAAQ,CAAC,4CAA4C,CAAC;CAC1D,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,mBAAmB,EACnB,6CAA6C,EAC7C,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC;gBAC3B,2BAA2B;gBAC3B,OAAO;gBACP,SAAS;gBACT,8BAA8B,IAAI,CAAC,IAAI,WAAW,IAAI,CAAC,KAAK,QAAQ;gBACpE,0BAA0B,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,oCAAoC;gBACrF,SAAS;gBACT,kCAAkC;gBAClC,6DAA6D;aAC9D,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAE3B,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fail2banStatus.d.ts","sourceRoot":"","sources":["../../src/tools/fail2banStatus.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"fail2banStatus.d.ts","sourceRoot":"","sources":["../../src/tools/fail2banStatus.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAYzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAiBhD"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const inputSchema = {
|
|
5
|
+
...nodeParam,
|
|
4
6
|
jail: z
|
|
5
7
|
.string()
|
|
6
8
|
.optional()
|
|
@@ -12,7 +14,7 @@ export function register(server) {
|
|
|
12
14
|
const cmd = args.jail
|
|
13
15
|
? `sudo fail2ban-client status '${args.jail}' 2>&1`
|
|
14
16
|
: "sudo fail2ban-client status 2>&1";
|
|
15
|
-
const output = await execSSH(cmd);
|
|
17
|
+
const output = await execSSH(cmd, args.node);
|
|
16
18
|
return { content: [{ type: "text", text: output }] };
|
|
17
19
|
}
|
|
18
20
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fail2banStatus.js","sourceRoot":"","sources":["../../src/tools/fail2banStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"fail2banStatus.js","sourceRoot":"","sources":["../../src/tools/fail2banStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,IAAI,EAAE,CAAC;SACJ,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,uEAAuE,CAAC;CACrF,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,wBAAwB,EACxB,iDAAiD,EACjD,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI;gBACnB,CAAC,CAAC,gCAAgC,IAAI,CAAC,IAAI,QAAQ;gBACnD,CAAC,CAAC,kCAAkC,CAAC;YACvC,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"grafanaSnapshot.d.ts","sourceRoot":"","sources":["../../src/tools/grafanaSnapshot.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"grafanaSnapshot.d.ts","sourceRoot":"","sources":["../../src/tools/grafanaSnapshot.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AA+BzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAuChD"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
3
|
import { CommandFailedError } from "../utils/errors.js";
|
|
4
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
4
5
|
const DEFAULT_PORT = 3000;
|
|
5
6
|
const SERVICE_NAME = "Grafana";
|
|
6
7
|
const inputSchema = {
|
|
8
|
+
...nodeParam,
|
|
7
9
|
dashboard: z.string().min(1).describe("Dashboard UID to export"),
|
|
8
10
|
};
|
|
9
11
|
function getPort() {
|
|
@@ -27,7 +29,7 @@ export function register(server) {
|
|
|
27
29
|
const port = getPort();
|
|
28
30
|
try {
|
|
29
31
|
const auth = buildAuthHeader();
|
|
30
|
-
const output = await execSSH(`curl -sf ${auth} 'http://localhost:${port}/api/dashboards/uid/${args.dashboard}'
|
|
32
|
+
const output = await execSSH(`curl -sf ${auth} 'http://localhost:${port}/api/dashboards/uid/${args.dashboard}'`, args.node);
|
|
31
33
|
return { content: [{ type: "text", text: output }] };
|
|
32
34
|
}
|
|
33
35
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"grafanaSnapshot.js","sourceRoot":"","sources":["../../src/tools/grafanaSnapshot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"grafanaSnapshot.js","sourceRoot":"","sources":["../../src/tools/grafanaSnapshot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,YAAY,GAAG,IAAI,CAAC;AAC1B,MAAM,YAAY,GAAG,SAAS,CAAC;AAE/B,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,yBAAyB,CAAC;CACjE,CAAC;AAEF,SAAS,OAAO;IACd,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC;IAClD,OAAO,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;AAC1D,CAAC;AAED,SAAS,eAAe;IACtB,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC;IAChD,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,6BAA6B,KAAK,GAAG,CAAC;IAC/C,CAAC;IACD,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,oBAAoB,IAAI,OAAO,CAAC;IACzD,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC;IACtD,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,OAAO,IAAI,IAAI,QAAQ,GAAG,CAAC;IACpC,CAAC;IACD,OAAO,kBAAkB,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,yBAAyB,EACzB,iDAAiD,EACjD,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,MAAM,IAAI,GAAG,OAAO,EAAE,CAAC;QACvB,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,eAAe,EAAE,CAAC;YAC/B,MAAM,MAAM,GAAG,MAAM,OAAO,CAC1B,YAAY,IAAI,sBAAsB,IAAI,uBAAuB,IAAI,CAAC,SAAS,GAAG,EAClF,IAAI,CAAC,IAAI,CACV,CAAC;YAEF,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,kBAAkB,EAAE,CAAC;gBACxC,IAAI,KAAK,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;oBACzB,OAAO,aAAa,CAClB,IAAI,KAAK,CACP,mBAAmB,YAAY,gBAAgB,IAAI,mBAAmB;wBACpE,uDAAuD,CAC1D,CACF,CAAC;gBACJ,CAAC;gBACD,IAAI,KAAK,CAAC,QAAQ,KAAK,EAAE,EAAE,CAAC;oBAC1B,OAAO,aAAa,CAClB,IAAI,KAAK,CACP,GAAG,YAAY,mDAAmD;wBAChE,wFAAwF;wBACxF,kCAAkC,IAAI,CAAC,SAAS,WAAW,CAC9D,CACF,CAAC;gBACJ,CAAC;YACH,CAAC;YACD,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inventorySync.d.ts","sourceRoot":"","sources":["../../src/tools/inventorySync.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AASzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAmChD"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
const inputSchema = {
|
|
4
|
+
source: z
|
|
5
|
+
.enum(["ansible", "tailscale"])
|
|
6
|
+
.describe("Discovery source: 'ansible' reads inventory file, 'tailscale' queries Tailscale peers"),
|
|
7
|
+
};
|
|
8
|
+
export function register(server) {
|
|
9
|
+
server.tool("homelab_inventorySync", "Discover nodes from Ansible inventory or Tailscale network", inputSchema, async (args) => {
|
|
10
|
+
try {
|
|
11
|
+
if (args.source === "ansible") {
|
|
12
|
+
const inventoryPath = process.env.HOMELAB_ANSIBLE_INVENTORY || "/etc/ansible/hosts";
|
|
13
|
+
const cmd = `test -f '${inventoryPath}' && cat '${inventoryPath}' || echo 'Inventory file not found at ${inventoryPath}. Set HOMELAB_ANSIBLE_INVENTORY to the correct path.'`;
|
|
14
|
+
const output = await execSSH(cmd);
|
|
15
|
+
return {
|
|
16
|
+
content: [{
|
|
17
|
+
type: "text",
|
|
18
|
+
text: `=== Ansible Inventory (${inventoryPath}) ===\n${output}`,
|
|
19
|
+
}],
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
const cmd = "command -v tailscale >/dev/null 2>&1 && tailscale status 2>&1 || echo 'Tailscale is not installed or not in PATH.'";
|
|
23
|
+
const output = await execSSH(cmd);
|
|
24
|
+
return {
|
|
25
|
+
content: [{
|
|
26
|
+
type: "text",
|
|
27
|
+
text: `=== Tailscale Peers ===\n${output}`,
|
|
28
|
+
}],
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
return errorResponse(error);
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=inventorySync.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inventorySync.js","sourceRoot":"","sources":["../../src/tools/inventorySync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE7D,MAAM,WAAW,GAAG;IAClB,MAAM,EAAE,CAAC;SACN,IAAI,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;SAC9B,QAAQ,CAAC,uFAAuF,CAAC;CACrG,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,uBAAuB,EACvB,4DAA4D,EAC5D,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC9B,MAAM,aAAa,GACjB,OAAO,CAAC,GAAG,CAAC,yBAAyB,IAAI,oBAAoB,CAAC;gBAChE,MAAM,GAAG,GACP,YAAY,aAAa,aAAa,aAAa,0CAA0C,aAAa,uDAAuD,CAAC;gBACpK,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;gBAClC,OAAO;oBACL,OAAO,EAAE,CAAC;4BACR,IAAI,EAAE,MAAe;4BACrB,IAAI,EAAE,0BAA0B,aAAa,UAAU,MAAM,EAAE;yBAChE,CAAC;iBACH,CAAC;YACJ,CAAC;YAED,MAAM,GAAG,GACP,oHAAoH,CAAC;YACvH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;YAClC,OAAO;gBACL,OAAO,EAAE,CAAC;wBACR,IAAI,EAAE,MAAe;wBACrB,IAAI,EAAE,4BAA4B,MAAM,EAAE;qBAC3C,CAAC;aACH,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"journalLogs.d.ts","sourceRoot":"","sources":["../../src/tools/journalLogs.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"journalLogs.d.ts","sourceRoot":"","sources":["../../src/tools/journalLogs.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AA8BzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAkBhD"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const inputSchema = {
|
|
5
|
+
...nodeParam,
|
|
4
6
|
unit: z
|
|
5
7
|
.string()
|
|
6
8
|
.optional()
|
|
@@ -34,7 +36,7 @@ export function register(server) {
|
|
|
34
36
|
parts.push(`--priority ${args.priority}`);
|
|
35
37
|
if (args.since)
|
|
36
38
|
parts.push(`--since '${args.since}'`);
|
|
37
|
-
const output = await execSSH(parts.join(" "));
|
|
39
|
+
const output = await execSSH(parts.join(" "), args.node);
|
|
38
40
|
return { content: [{ type: "text", text: output || "No journal entries matched the filters." }] };
|
|
39
41
|
}
|
|
40
42
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"journalLogs.js","sourceRoot":"","sources":["../../src/tools/journalLogs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"journalLogs.js","sourceRoot":"","sources":["../../src/tools/journalLogs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,IAAI,EAAE,CAAC;SACJ,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,gEAAgE,CAAC;IAC7E,QAAQ,EAAE,CAAC;SACR,MAAM,EAAE;SACR,GAAG,EAAE;SACL,GAAG,CAAC,CAAC,CAAC;SACN,GAAG,CAAC,CAAC,CAAC;SACN,QAAQ,EAAE;SACV,QAAQ,CAAC,wEAAwE,CAAC;IACrF,KAAK,EAAE,CAAC;SACL,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,6DAA6D,CAAC;IAC1E,KAAK,EAAE,CAAC;SACL,MAAM,EAAE;SACR,GAAG,EAAE;SACL,QAAQ,EAAE;SACV,QAAQ,EAAE;SACV,OAAO,CAAC,EAAE,CAAC;SACX,QAAQ,CAAC,mCAAmC,CAAC;CACjD,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,qBAAqB,EACrB,kEAAkE,EAClE,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,CAAC,YAAY,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YAC/D,IAAI,IAAI,CAAC,IAAI;gBAAE,KAAK,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;YACnD,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS;gBAAE,KAAK,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC3E,IAAI,IAAI,CAAC,KAAK;gBAAE,KAAK,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACtD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACzD,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,IAAI,yCAAyC,EAAE,CAAC,EAAE,CAAC;QAC7G,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kernelInfo.d.ts","sourceRoot":"","sources":["../../src/tools/kernelInfo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"kernelInfo.d.ts","sourceRoot":"","sources":["../../src/tools/kernelInfo.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAMzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAwBhD"}
|
package/dist/tools/kernelInfo.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
2
|
-
|
|
2
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
|
+
const inputSchema = { ...nodeParam };
|
|
3
4
|
export function register(server) {
|
|
4
|
-
server.tool("homelab_kernelInfo", "Show kernel version, boot parameters, and loaded modules", inputSchema, async () => {
|
|
5
|
+
server.tool("homelab_kernelInfo", "Show kernel version, boot parameters, and loaded modules", inputSchema, async (args) => {
|
|
5
6
|
try {
|
|
6
7
|
const cmd = [
|
|
7
8
|
"echo '=== Kernel ==='",
|
|
@@ -13,7 +14,7 @@ export function register(server) {
|
|
|
13
14
|
"echo '=== Loaded Modules (top 30) ==='",
|
|
14
15
|
"lsmod | head -31",
|
|
15
16
|
].join(" && ");
|
|
16
|
-
const output = await execSSH(cmd);
|
|
17
|
+
const output = await execSSH(cmd, args.node);
|
|
17
18
|
return { content: [{ type: "text", text: output }] };
|
|
18
19
|
}
|
|
19
20
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kernelInfo.js","sourceRoot":"","sources":["../../src/tools/kernelInfo.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"kernelInfo.js","sourceRoot":"","sources":["../../src/tools/kernelInfo.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC;AAErC,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,oBAAoB,EACpB,0DAA0D,EAC1D,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,GAAG,GAAG;gBACV,uBAAuB;gBACvB,UAAU;gBACV,MAAM;gBACN,gCAAgC;gBAChC,mBAAmB;gBACnB,MAAM;gBACN,wCAAwC;gBACxC,kBAAkB;aACnB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACf,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logSearch.d.ts","sourceRoot":"","sources":["../../src/tools/logSearch.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"logSearch.d.ts","sourceRoot":"","sources":["../../src/tools/logSearch.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAuBzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAkBhD"}
|
package/dist/tools/logSearch.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { z } from "zod";
|
|
2
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
3
4
|
const inputSchema = {
|
|
5
|
+
...nodeParam,
|
|
4
6
|
pattern: z
|
|
5
7
|
.string()
|
|
6
8
|
.min(1)
|
|
@@ -24,7 +26,7 @@ export function register(server) {
|
|
|
24
26
|
const cmd = args.service
|
|
25
27
|
? `docker logs '${args.service}' 2>&1 | grep -i '${escaped}' | tail -${args.lines}`
|
|
26
28
|
: `docker ps --format '{{.Names}}' | while read name; do matches=$(docker logs "$name" 2>&1 | grep -i '${escaped}' | tail -${args.lines}); if [ -n "$matches" ]; then echo "=== $name ==="; echo "$matches"; echo; fi; done`;
|
|
27
|
-
const output = await execSSH(cmd);
|
|
29
|
+
const output = await execSSH(cmd, args.node);
|
|
28
30
|
return { content: [{ type: "text", text: output || `No matches found for pattern '${args.pattern}'.` }] };
|
|
29
31
|
}
|
|
30
32
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logSearch.js","sourceRoot":"","sources":["../../src/tools/logSearch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"logSearch.js","sourceRoot":"","sources":["../../src/tools/logSearch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,WAAW,GAAG;IAClB,GAAG,SAAS;IACZ,OAAO,EAAE,CAAC;SACP,MAAM,EAAE;SACR,GAAG,CAAC,CAAC,CAAC;SACN,QAAQ,CAAC,8CAA8C,CAAC;IAC3D,OAAO,EAAE,CAAC;SACP,MAAM,EAAE;SACR,QAAQ,EAAE;SACV,QAAQ,CAAC,sEAAsE,CAAC;IACnF,KAAK,EAAE,CAAC;SACL,MAAM,EAAE;SACR,GAAG,EAAE;SACL,QAAQ,EAAE;SACV,QAAQ,EAAE;SACV,OAAO,CAAC,GAAG,CAAC;SACZ,QAAQ,CAAC,kCAAkC,CAAC;CAChD,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,mBAAmB,EACnB,wDAAwD,EACxD,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YACpD,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO;gBACtB,CAAC,CAAC,gBAAgB,IAAI,CAAC,OAAO,qBAAqB,OAAO,aAAa,IAAI,CAAC,KAAK,EAAE;gBACnF,CAAC,CAAC,uGAAuG,OAAO,aAAa,IAAI,CAAC,KAAK,qFAAqF,CAAC;YAC/N,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,IAAI,iCAAiC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE,CAAC;QACrH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"networkInfo.d.ts","sourceRoot":"","sources":["../../src/tools/networkInfo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;
|
|
1
|
+
{"version":3,"file":"networkInfo.d.ts","sourceRoot":"","sources":["../../src/tools/networkInfo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAIzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CA2BhD"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
import { nodeParam } from "../utils/node-param.js";
|
|
1
2
|
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
2
3
|
export function register(server) {
|
|
3
|
-
server.tool("homelab_networkInfo", "Get network info from the Pi: IP addresses, interfaces, DNS, and Tailscale status", {}, async () => {
|
|
4
|
+
server.tool("homelab_networkInfo", "Get network info from the Pi: IP addresses, interfaces, DNS, and Tailscale status", { ...nodeParam }, async (args) => {
|
|
4
5
|
try {
|
|
5
6
|
const output = await execSSH([
|
|
6
7
|
'echo "=== IP Addresses ==="',
|
|
@@ -14,7 +15,7 @@ export function register(server) {
|
|
|
14
15
|
'echo ""',
|
|
15
16
|
'echo "=== Tailscale ==="',
|
|
16
17
|
"tailscale status 2>/dev/null || echo 'Tailscale not installed or not running'",
|
|
17
|
-
].join(" && "));
|
|
18
|
+
].join(" && "), args.node);
|
|
18
19
|
return { content: [{ type: "text", text: output }] };
|
|
19
20
|
}
|
|
20
21
|
catch (error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"networkInfo.js","sourceRoot":"","sources":["../../src/tools/networkInfo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE7D,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,qBAAqB,EACrB,mFAAmF,EACnF,EAAE,
|
|
1
|
+
{"version":3,"file":"networkInfo.js","sourceRoot":"","sources":["../../src/tools/networkInfo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE7D,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,qBAAqB,EACrB,mFAAmF,EACnF,EAAE,GAAG,SAAS,EAAE,EAChB,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC;gBAC3B,6BAA6B;gBAC7B,qDAAqD;gBACrD,SAAS;gBACT,gCAAgC;gBAChC,yBAAyB;gBACzB,SAAS;gBACT,oBAAoB;gBACpB,wCAAwC;gBACxC,SAAS;gBACT,0BAA0B;gBAC1B,+EAA+E;aAChF,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAE3B,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nodeExec.d.ts","sourceRoot":"","sources":["../../src/tools/nodeExec.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAWzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CA4BhD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { execSSH, errorResponse } from "../utils/ssh-api.js";
|
|
3
|
+
const inputSchema = {
|
|
4
|
+
node: z.string().min(1).describe("Target node name from the node registry"),
|
|
5
|
+
command: z.string().min(1).describe("Shell command to execute on the node"),
|
|
6
|
+
confirm: z
|
|
7
|
+
.boolean()
|
|
8
|
+
.describe("Safety gate -- must be true to execute arbitrary commands"),
|
|
9
|
+
};
|
|
10
|
+
export function register(server) {
|
|
11
|
+
server.tool("homelab_nodeExec", "Execute a shell command on a specific node by name", inputSchema, async (args) => {
|
|
12
|
+
if (!args.confirm) {
|
|
13
|
+
return {
|
|
14
|
+
content: [{
|
|
15
|
+
type: "text",
|
|
16
|
+
text: "Execution aborted -- set confirm=true to proceed.",
|
|
17
|
+
}],
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
const output = await execSSH(args.command, args.node);
|
|
22
|
+
return {
|
|
23
|
+
content: [{
|
|
24
|
+
type: "text",
|
|
25
|
+
text: output || "(command produced no output)",
|
|
26
|
+
}],
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
catch (error) {
|
|
30
|
+
return errorResponse(error);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=nodeExec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nodeExec.js","sourceRoot":"","sources":["../../src/tools/nodeExec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAE7D,MAAM,WAAW,GAAG;IAClB,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,yCAAyC,CAAC;IAC3E,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,sCAAsC,CAAC;IAC3E,OAAO,EAAE,CAAC;SACP,OAAO,EAAE;SACT,QAAQ,CAAC,2DAA2D,CAAC;CACzE,CAAC;AAEF,MAAM,UAAU,QAAQ,CAAC,MAAiB;IACxC,MAAM,CAAC,IAAI,CACT,kBAAkB,EAClB,oDAAoD,EACpD,WAAW,EACX,KAAK,EAAE,IAAI,EAAE,EAAE;QACb,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO;gBACL,OAAO,EAAE,CAAC;wBACR,IAAI,EAAE,MAAe;wBACrB,IAAI,EAAE,mDAAmD;qBAC1D,CAAC;aACH,CAAC;QACJ,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACtD,OAAO;gBACL,OAAO,EAAE,CAAC;wBACR,IAAI,EAAE,MAAe;wBACrB,IAAI,EAAE,MAAM,IAAI,8BAA8B;qBAC/C,CAAC;aACH,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nodeList.d.ts","sourceRoot":"","sources":["../../src/tools/nodeList.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAKzE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CA0BhD"}
|