@basilica/openclaw 0.8.2 → 0.8.3
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/gateway/agent-status.d.ts +3 -0
- package/dist/gateway/agent-status.d.ts.map +1 -0
- package/dist/gateway/agent-status.js +102 -0
- package/dist/gateway/agent-status.js.map +1 -0
- package/dist/gateway/index.d.ts.map +1 -1
- package/dist/gateway/index.js +7 -0
- package/dist/gateway/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-status.d.ts","sourceRoot":"","sources":["../../src/gateway/agent-status.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AA4HvE,wBAAsB,iBAAiB,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC,CAKhF"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { readFileSync } from "node:fs";
|
|
2
|
+
function fileExists(path) {
|
|
3
|
+
try {
|
|
4
|
+
readFileSync(path);
|
|
5
|
+
return true;
|
|
6
|
+
}
|
|
7
|
+
catch {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
function readEvmAddress() {
|
|
12
|
+
try {
|
|
13
|
+
const data = JSON.parse(readFileSync("/data/.evm/agent.json", "utf-8"));
|
|
14
|
+
const wallet = Array.isArray(data) ? data[0] : data;
|
|
15
|
+
return wallet?.address;
|
|
16
|
+
}
|
|
17
|
+
catch {
|
|
18
|
+
return undefined;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function countTools() {
|
|
22
|
+
// Read from MCP bridge health if available, otherwise estimate from env
|
|
23
|
+
try {
|
|
24
|
+
const res = readFileSync("/tmp/basilica-tool-count.txt", "utf-8").trim();
|
|
25
|
+
return parseInt(res, 10) || 0;
|
|
26
|
+
}
|
|
27
|
+
catch {
|
|
28
|
+
// Estimate based on enabled plugins
|
|
29
|
+
let count = 40; // core basilica + btcli + evm + ssh + mining + deposits
|
|
30
|
+
if (process.env.TAOSTATS_API_KEY)
|
|
31
|
+
count += 29;
|
|
32
|
+
if (process.env.ENABLE_CHI === "1")
|
|
33
|
+
count += 3;
|
|
34
|
+
if (process.env.ENABLE_NUMINOUS === "1" && process.env.NUMINOUS_API_KEY)
|
|
35
|
+
count += 7;
|
|
36
|
+
if (process.env.ENABLE_SYNTHDATA === "1" && process.env.SYNTHDATA_API_KEY)
|
|
37
|
+
count += 11;
|
|
38
|
+
return count;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
function buildStatus() {
|
|
42
|
+
const btWalletPath = process.env.BT_WALLET_PATH ?? "/data/.bittensor/wallets";
|
|
43
|
+
const sshKeyPath = process.env.AGENT_SSH_KEY ?? "/data/.ssh/id_ed25519";
|
|
44
|
+
const evmAddress = readEvmAddress();
|
|
45
|
+
return {
|
|
46
|
+
wallets: {
|
|
47
|
+
bittensor: {
|
|
48
|
+
exists: fileExists(`${btWalletPath}/agent/coldkeypub.txt`),
|
|
49
|
+
name: "agent",
|
|
50
|
+
path: btWalletPath,
|
|
51
|
+
address: (() => {
|
|
52
|
+
try {
|
|
53
|
+
return readFileSync(`${btWalletPath}/agent/coldkeypub.txt`, "utf-8").trim();
|
|
54
|
+
}
|
|
55
|
+
catch {
|
|
56
|
+
return undefined;
|
|
57
|
+
}
|
|
58
|
+
})(),
|
|
59
|
+
},
|
|
60
|
+
evm: {
|
|
61
|
+
exists: !!evmAddress,
|
|
62
|
+
path: "/data/.evm",
|
|
63
|
+
address: evmAddress,
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
sshKey: {
|
|
67
|
+
exists: fileExists(sshKeyPath),
|
|
68
|
+
path: sshKeyPath,
|
|
69
|
+
},
|
|
70
|
+
plugins: {
|
|
71
|
+
taostats: {
|
|
72
|
+
enabled: !!process.env.TAOSTATS_API_KEY,
|
|
73
|
+
hasKey: !!process.env.TAOSTATS_API_KEY,
|
|
74
|
+
},
|
|
75
|
+
chi: {
|
|
76
|
+
enabled: process.env.ENABLE_CHI === "1",
|
|
77
|
+
hasKey: true, // chi is public, no key needed
|
|
78
|
+
},
|
|
79
|
+
numinous: {
|
|
80
|
+
enabled: process.env.ENABLE_NUMINOUS === "1" && !!process.env.NUMINOUS_API_KEY,
|
|
81
|
+
hasKey: !!process.env.NUMINOUS_API_KEY,
|
|
82
|
+
},
|
|
83
|
+
synthdata: {
|
|
84
|
+
enabled: process.env.ENABLE_SYNTHDATA === "1" && !!process.env.SYNTHDATA_API_KEY,
|
|
85
|
+
hasKey: !!process.env.SYNTHDATA_API_KEY,
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
toolCount: countTools(),
|
|
89
|
+
env: {
|
|
90
|
+
basilicaApiKey: !!process.env.BASILICA_API_KEY,
|
|
91
|
+
model: process.env.OPENCLAW_MODEL_ID ?? "unknown",
|
|
92
|
+
baseUrl: process.env.OPENCLAW_BASE_URL ?? "unknown",
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
export async function handleAgentStatus(_req) {
|
|
97
|
+
return {
|
|
98
|
+
status: 200,
|
|
99
|
+
body: buildStatus(),
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=agent-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-status.js","sourceRoot":"","sources":["../../src/gateway/agent-status.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/gateway/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/gateway/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAM/D,wBAAgB,uBAAuB,CAAC,GAAG,EAAE,iBAAiB,GAAG,IAAI,CAwBpE;AAED,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACzE,YAAY,EAAE,cAAc,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AACtF,YAAY,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/gateway/index.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { handleStatus } from "./status.js";
|
|
2
2
|
import { handleWebhook } from "./webhook.js";
|
|
3
|
+
import { handleAgentStatus } from "./agent-status.js";
|
|
3
4
|
import { BasilicaSyncService } from "./sync-service.js";
|
|
4
5
|
export function registerBasilicaGateway(api) {
|
|
5
6
|
api.registerGatewayMethod("basilica.status", handleStatus);
|
|
@@ -9,6 +10,12 @@ export function registerBasilicaGateway(api) {
|
|
|
9
10
|
auth: "plugin",
|
|
10
11
|
handler: handleWebhook,
|
|
11
12
|
});
|
|
13
|
+
api.registerHttpRoute({
|
|
14
|
+
path: "/basilica/agent-status",
|
|
15
|
+
method: "GET",
|
|
16
|
+
auth: "plugin",
|
|
17
|
+
handler: handleAgentStatus,
|
|
18
|
+
});
|
|
12
19
|
const syncService = new BasilicaSyncService();
|
|
13
20
|
api.registerService({
|
|
14
21
|
id: "basilica-sync",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/gateway/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAExD,MAAM,UAAU,uBAAuB,CAAC,GAAsB;IAC5D,GAAG,CAAC,qBAAqB,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;IAE3D,GAAG,CAAC,iBAAiB,CAAC;QACpB,IAAI,EAAE,mBAAmB;QACzB,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,aAAa;KACvB,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAE9C,GAAG,CAAC,eAAe,CAAC;QAClB,EAAE,EAAE,eAAe;QACnB,KAAK,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE;QAChC,IAAI,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,EAAE;KAC/B,CAAC,CAAC;AACL,CAAC;AAED,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/gateway/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAExD,MAAM,UAAU,uBAAuB,CAAC,GAAsB;IAC5D,GAAG,CAAC,qBAAqB,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;IAE3D,GAAG,CAAC,iBAAiB,CAAC;QACpB,IAAI,EAAE,mBAAmB;QACzB,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,aAAa;KACvB,CAAC,CAAC;IAEH,GAAG,CAAC,iBAAiB,CAAC;QACpB,IAAI,EAAE,wBAAwB;QAC9B,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,iBAAiB;KAC3B,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAE9C,GAAG,CAAC,eAAe,CAAC;QAClB,EAAE,EAAE,eAAe;QACnB,KAAK,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE;QAChC,IAAI,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,EAAE;KAC/B,CAAC,CAAC;AACL,CAAC;AAED,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@basilica/openclaw",
|
|
3
|
-
"version": "0.8.
|
|
3
|
+
"version": "0.8.3",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Basilica platform tools, hooks, skills, and gateway integration for OpenClaw",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
"clean": "rm -rf dist"
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@basilica/sdk": "^0.8.
|
|
31
|
+
"@basilica/sdk": "^0.8.3"
|
|
32
32
|
},
|
|
33
33
|
"devDependencies": {
|
|
34
34
|
"@types/node": "^25.5.0",
|