@enshell/cli 0.1.0-beta.1 → 0.1.0-beta.17
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/commands/activate.d.ts +2 -0
- package/dist/commands/activate.js +26 -0
- package/dist/commands/activate.js.map +1 -0
- package/dist/commands/approve.js +2 -2
- package/dist/commands/approve.js.map +1 -1
- package/dist/commands/deactivate.js +2 -2
- package/dist/commands/deactivate.js.map +1 -1
- package/dist/commands/freeze.d.ts +2 -0
- package/dist/commands/freeze.js +26 -0
- package/dist/commands/freeze.js.map +1 -0
- package/dist/commands/list.js +34 -9
- package/dist/commands/list.js.map +1 -1
- package/dist/commands/protect.js +60 -7
- package/dist/commands/protect.js.map +1 -1
- package/dist/commands/reactivate.js +2 -2
- package/dist/commands/reactivate.js.map +1 -1
- package/dist/commands/register.js +2 -2
- package/dist/commands/register.js.map +1 -1
- package/dist/commands/reject.js +2 -2
- package/dist/commands/reject.js.map +1 -1
- package/dist/commands/submit.js +2 -2
- package/dist/commands/submit.js.map +1 -1
- package/dist/config.d.ts +2 -0
- package/dist/config.js +6 -2
- package/dist/config.js.map +1 -1
- package/dist/index.js +8 -11
- package/dist/index.js.map +1 -1
- package/dist/wallets/walletconnect.js +1 -1
- package/dist/wallets/walletconnect.js.map +1 -1
- package/package.json +2 -2
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import ora from "ora";
|
|
4
|
+
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
|
+
export const activateCommand = new Command("activate")
|
|
7
|
+
.description("Activate a frozen agent")
|
|
8
|
+
.requiredOption("--id <agentId>", "Agent identifier")
|
|
9
|
+
.action(async (opts) => {
|
|
10
|
+
const spinner = ora(`Activating agent${walletHint()}...`).start();
|
|
11
|
+
try {
|
|
12
|
+
const signer = await getSigner();
|
|
13
|
+
const client = new ENShell({
|
|
14
|
+
network: Network.SEPOLIA,
|
|
15
|
+
signer,
|
|
16
|
+
});
|
|
17
|
+
const { txHash } = await client.reactivateAgent(opts.id);
|
|
18
|
+
spinner.succeed(chalk.green(`Agent "${opts.id}" activated`));
|
|
19
|
+
console.log(chalk.gray(` tx: https://sepolia.etherscan.io/tx/${txHash}`));
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
spinner.fail(chalk.red(`Activation failed: ${err.message}`));
|
|
23
|
+
process.exit(1);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=activate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activate.js","sourceRoot":"","sources":["../../src/commands/activate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,OAAO,CAAC,UAAU,CAAC;KACnD,WAAW,CAAC,yBAAyB,CAAC;KACtC,cAAc,CAAC,gBAAgB,EAAE,kBAAkB,CAAC;KACpD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,mBAAmB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEzD,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,IAAI,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC;QAC7D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,sBAAsB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC7D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
package/dist/commands/approve.js
CHANGED
|
@@ -2,12 +2,12 @@ import { Command } from "commander";
|
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import ora from "ora";
|
|
4
4
|
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
-
import { getSigner } from "../config.js";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
6
|
export const approveCommand = new Command("approve")
|
|
7
7
|
.description("Approve a queued action")
|
|
8
8
|
.requiredOption("--action-id <id>", "Queued action ID")
|
|
9
9
|
.action(async (opts) => {
|
|
10
|
-
const spinner = ora(
|
|
10
|
+
const spinner = ora(`Approving action${walletHint()}...`).start();
|
|
11
11
|
try {
|
|
12
12
|
const signer = await getSigner();
|
|
13
13
|
const client = new ENShell({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"approve.js","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"approve.js","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,SAAS,CAAC;KACjD,WAAW,CAAC,yBAAyB,CAAC;KACtC,cAAc,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;KACtD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,mBAAmB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAErE,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,QAAQ,WAAW,CAAC,CAAC,CAAC;QAClE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,oBAAoB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC3D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -2,12 +2,12 @@ import { Command } from "commander";
|
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import ora from "ora";
|
|
4
4
|
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
-
import { getSigner } from "../config.js";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
6
|
export const deactivateCommand = new Command("deactivate")
|
|
7
7
|
.description("Deactivate (freeze) an agent")
|
|
8
8
|
.requiredOption("--id <agentId>", "Agent identifier")
|
|
9
9
|
.action(async (opts) => {
|
|
10
|
-
const spinner = ora(
|
|
10
|
+
const spinner = ora(`Deactivating agent${walletHint()}...`).start();
|
|
11
11
|
try {
|
|
12
12
|
const signer = await getSigner();
|
|
13
13
|
const client = new ENShell({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"deactivate.js","sourceRoot":"","sources":["../../src/commands/deactivate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"deactivate.js","sourceRoot":"","sources":["../../src/commands/deactivate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,OAAO,CAAC,YAAY,CAAC;KACvD,WAAW,CAAC,8BAA8B,CAAC;KAC3C,cAAc,CAAC,gBAAgB,EAAE,kBAAkB,CAAC;KACpD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,qBAAqB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAEpE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEzD,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,IAAI,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,wBAAwB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import chalk from "chalk";
|
|
3
|
+
import ora from "ora";
|
|
4
|
+
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
|
+
export const freezeCommand = new Command("freeze")
|
|
7
|
+
.description("Freeze an agent")
|
|
8
|
+
.requiredOption("--id <agentId>", "Agent identifier")
|
|
9
|
+
.action(async (opts) => {
|
|
10
|
+
const spinner = ora(`Freezing agent${walletHint()}...`).start();
|
|
11
|
+
try {
|
|
12
|
+
const signer = await getSigner();
|
|
13
|
+
const client = new ENShell({
|
|
14
|
+
network: Network.SEPOLIA,
|
|
15
|
+
signer,
|
|
16
|
+
});
|
|
17
|
+
const { txHash } = await client.deactivateAgent(opts.id);
|
|
18
|
+
spinner.succeed(chalk.green(`Agent "${opts.id}" frozen`));
|
|
19
|
+
console.log(chalk.gray(` tx: https://sepolia.etherscan.io/tx/${txHash}`));
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
spinner.fail(chalk.red(`Freeze failed: ${err.message}`));
|
|
23
|
+
process.exit(1);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=freeze.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"freeze.js","sourceRoot":"","sources":["../../src/commands/freeze.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,aAAa,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC;KAC/C,WAAW,CAAC,iBAAiB,CAAC;KAC9B,cAAc,CAAC,gBAAgB,EAAE,kBAAkB,CAAC;KACpD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,iBAAiB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAEhE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEzD,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC;QAC1D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,kBAAkB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QACzD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
package/dist/commands/list.js
CHANGED
|
@@ -1,26 +1,51 @@
|
|
|
1
1
|
import { Command } from "commander";
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import ora from "ora";
|
|
4
|
-
import { getContract } from "../config.js";
|
|
4
|
+
import { getContract, getSigner } from "../config.js";
|
|
5
5
|
export const listCommand = new Command("list")
|
|
6
|
-
.description("List
|
|
7
|
-
.
|
|
6
|
+
.description("List your registered agents")
|
|
7
|
+
.option("--all", "List all agents on the network (not just yours)")
|
|
8
|
+
.action(async (opts) => {
|
|
8
9
|
const spinner = ora("Fetching agents...").start();
|
|
9
10
|
try {
|
|
10
11
|
const contract = getContract();
|
|
11
12
|
const count = await contract.getAgentCount();
|
|
12
13
|
if (count === 0n) {
|
|
13
|
-
spinner.info("No agents registered.");
|
|
14
|
+
spinner.info("No agents registered on the network.");
|
|
14
15
|
return;
|
|
15
16
|
}
|
|
16
|
-
|
|
17
|
+
// Get connected wallet address for filtering
|
|
18
|
+
let myAddress = null;
|
|
19
|
+
if (!opts.all) {
|
|
20
|
+
try {
|
|
21
|
+
const signer = await getSigner();
|
|
22
|
+
myAddress = (await signer.getAddress()).toLowerCase();
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
// If no wallet connected, show all with a hint
|
|
26
|
+
spinner.warn("No wallet connected. Showing all agents. Use --all to suppress this warning.");
|
|
27
|
+
myAddress = null;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
const agents = [];
|
|
17
31
|
for (let i = 0n; i < count; i++) {
|
|
18
|
-
|
|
32
|
+
const id = await contract.agentIds(i);
|
|
33
|
+
const agent = await contract.getAgent(id);
|
|
34
|
+
if (myAddress && agent.owner.toLowerCase() !== myAddress)
|
|
35
|
+
continue;
|
|
36
|
+
agents.push({ id, active: agent.active, score: agent.threatScore });
|
|
19
37
|
}
|
|
20
38
|
spinner.stop();
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
39
|
+
if (agents.length === 0) {
|
|
40
|
+
console.log(chalk.gray("\n No agents found for your wallet.\n"));
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const label = myAddress ? "Your agents" : "All agents";
|
|
44
|
+
console.log(chalk.bold(`\n${label} (${agents.length}):\n`));
|
|
45
|
+
for (const a of agents) {
|
|
46
|
+
const status = a.active ? chalk.green("ACTIVE") : chalk.red("FROZEN");
|
|
47
|
+
const score = chalk.gray(`score: ${(Number(a.score) / 1000).toFixed(1)}`);
|
|
48
|
+
console.log(` ${chalk.cyan(a.id + ".enshell.eth")} ${status} ${score}`);
|
|
24
49
|
}
|
|
25
50
|
console.log();
|
|
26
51
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../src/commands/list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../src/commands/list.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/protect.js
CHANGED
|
@@ -1,8 +1,45 @@
|
|
|
1
|
+
import { createInterface } from "node:readline";
|
|
1
2
|
import { Command } from "commander";
|
|
2
3
|
import chalk from "chalk";
|
|
3
4
|
import ora from "ora";
|
|
4
5
|
import { ENShell, Network, ActionDecision } from "@enshell/sdk";
|
|
5
|
-
import { getSigner } from "../config.js";
|
|
6
|
+
import { getSigner, walletHint } from "../config.js";
|
|
7
|
+
function prompt(question) {
|
|
8
|
+
const rl = createInterface({ input: process.stdin, output: process.stdout });
|
|
9
|
+
return new Promise((resolve) => {
|
|
10
|
+
rl.question(question, (answer) => {
|
|
11
|
+
rl.close();
|
|
12
|
+
resolve(answer.trim().toLowerCase());
|
|
13
|
+
});
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
function displayAnalysis(result, actionId) {
|
|
17
|
+
const a = result.analysis;
|
|
18
|
+
const score = a ? (a.score / 1000).toFixed(1) : "?";
|
|
19
|
+
const label = result.decision === ActionDecision.ESCALATED ? "ESCALATED" : "BLOCKED";
|
|
20
|
+
const color = result.decision === ActionDecision.ESCALATED ? chalk.yellow : chalk.red;
|
|
21
|
+
console.log("");
|
|
22
|
+
console.log(color(` ${result.decision === ActionDecision.ESCALATED ? "\u26a0" : "\u2718"} Action #${actionId} ${label} by CRE oracle`));
|
|
23
|
+
console.log("");
|
|
24
|
+
console.log(chalk.gray(` Score: `) + color(`${score} / 100`));
|
|
25
|
+
if (a?.agentId)
|
|
26
|
+
console.log(chalk.gray(` Agent: `) + chalk.cyan(`${a.agentId}.enshell.eth`));
|
|
27
|
+
if (a?.target)
|
|
28
|
+
console.log(chalk.gray(` Target: `) + chalk.white(a.target));
|
|
29
|
+
if (a?.instruction)
|
|
30
|
+
console.log(chalk.gray(` Instruction: `) + chalk.green(`"${a.instruction}"`));
|
|
31
|
+
console.log("");
|
|
32
|
+
if (a?.reasoning) {
|
|
33
|
+
console.log(chalk.gray(" Analysis:"));
|
|
34
|
+
console.log(chalk.gray(" " + "\u2500".repeat(50)));
|
|
35
|
+
const lines = a.reasoning.replace(/\. /g, ".\n ").split("\n");
|
|
36
|
+
for (const line of lines) {
|
|
37
|
+
console.log(chalk.white(` ${line}`));
|
|
38
|
+
}
|
|
39
|
+
console.log(chalk.gray(" " + "\u2500".repeat(50)));
|
|
40
|
+
}
|
|
41
|
+
console.log("");
|
|
42
|
+
}
|
|
6
43
|
export const protectCommand = new Command("protect")
|
|
7
44
|
.description("Submit an action through the ENShell firewall with encryption and relay")
|
|
8
45
|
.requiredOption("--id <agentId>", "Agent identifier")
|
|
@@ -18,7 +55,7 @@ export const protectCommand = new Command("protect")
|
|
|
18
55
|
signer,
|
|
19
56
|
});
|
|
20
57
|
// Step 1: Encrypt + relay + submit
|
|
21
|
-
const submitSpinner = ora(
|
|
58
|
+
const submitSpinner = ora(`Encrypting and submitting action${walletHint()}...`).start();
|
|
22
59
|
const result = await client.protect(opts.id, {
|
|
23
60
|
instruction: opts.instruction,
|
|
24
61
|
tx: {
|
|
@@ -31,19 +68,35 @@ export const protectCommand = new Command("protect")
|
|
|
31
68
|
console.log(chalk.gray(` tx: https://sepolia.etherscan.io/tx/${result.txHash}`));
|
|
32
69
|
// Step 2: Wait for CRE resolution
|
|
33
70
|
const waitSpinner = ora("Waiting for CRE oracle resolution...").start();
|
|
34
|
-
const
|
|
35
|
-
switch (decision) {
|
|
71
|
+
const resolution = await result.waitForResolution();
|
|
72
|
+
switch (resolution.decision) {
|
|
36
73
|
case ActionDecision.APPROVED:
|
|
37
74
|
waitSpinner.succeed(chalk.green("Action approved by CRE oracle"));
|
|
38
75
|
break;
|
|
39
|
-
case ActionDecision.ESCALATED:
|
|
40
|
-
waitSpinner.warn(chalk.yellow("Action escalated
|
|
76
|
+
case ActionDecision.ESCALATED: {
|
|
77
|
+
waitSpinner.warn(chalk.yellow("Action escalated — human approval required"));
|
|
78
|
+
displayAnalysis(resolution, result.actionId);
|
|
79
|
+
const answer = await prompt(chalk.yellow(" ? Approve this action? (y/n) "));
|
|
80
|
+
if (answer === "y" || answer === "yes") {
|
|
81
|
+
const approveSpinner = ora(`Approving action #${result.actionId}${walletHint()}...`).start();
|
|
82
|
+
const { txHash } = await client.approveAction(result.actionId);
|
|
83
|
+
approveSpinner.succeed(chalk.green(`Action #${result.actionId} approved`));
|
|
84
|
+
console.log(chalk.gray(` tx: https://sepolia.etherscan.io/tx/${txHash}`));
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
const rejectSpinner = ora(`Rejecting action #${result.actionId}${walletHint()}...`).start();
|
|
88
|
+
const { txHash } = await client.rejectAction(result.actionId);
|
|
89
|
+
rejectSpinner.succeed(chalk.red(`Action #${result.actionId} rejected`));
|
|
90
|
+
console.log(chalk.gray(` tx: https://sepolia.etherscan.io/tx/${txHash}`));
|
|
91
|
+
}
|
|
41
92
|
break;
|
|
93
|
+
}
|
|
42
94
|
case ActionDecision.BLOCKED:
|
|
43
95
|
waitSpinner.fail(chalk.red("Action blocked by CRE oracle"));
|
|
96
|
+
displayAnalysis(resolution, result.actionId);
|
|
44
97
|
break;
|
|
45
98
|
default:
|
|
46
|
-
waitSpinner.info(`Decision: ${decision}`);
|
|
99
|
+
waitSpinner.info(`Decision: ${resolution.decision}`);
|
|
47
100
|
}
|
|
48
101
|
}
|
|
49
102
|
catch (err) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"protect.js","sourceRoot":"","sources":["../../src/commands/protect.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"protect.js","sourceRoot":"","sources":["../../src/commands/protect.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,12 +2,12 @@ import { Command } from "commander";
|
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import ora from "ora";
|
|
4
4
|
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
-
import { getSigner } from "../config.js";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
6
|
export const reactivateCommand = new Command("reactivate")
|
|
7
7
|
.description("Reactivate a frozen agent")
|
|
8
8
|
.requiredOption("--id <agentId>", "Agent identifier")
|
|
9
9
|
.action(async (opts) => {
|
|
10
|
-
const spinner = ora(
|
|
10
|
+
const spinner = ora(`Reactivating agent${walletHint()}...`).start();
|
|
11
11
|
try {
|
|
12
12
|
const signer = await getSigner();
|
|
13
13
|
const client = new ENShell({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reactivate.js","sourceRoot":"","sources":["../../src/commands/reactivate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"reactivate.js","sourceRoot":"","sources":["../../src/commands/reactivate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,OAAO,CAAC,YAAY,CAAC;KACvD,WAAW,CAAC,2BAA2B,CAAC;KACxC,cAAc,CAAC,gBAAgB,EAAE,kBAAkB,CAAC;KACpD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,qBAAqB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAEpE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEzD,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,IAAI,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,wBAAwB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC/D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
|
@@ -2,7 +2,7 @@ import { Command } from "commander";
|
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import ora from "ora";
|
|
4
4
|
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
-
import { getSigner } from "../config.js";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
6
|
export const registerCommand = new Command("register")
|
|
7
7
|
.description("Register a new AI agent on the firewall")
|
|
8
8
|
.requiredOption("--id <agentId>", "Unique agent identifier (becomes <id>.enshell.eth)")
|
|
@@ -16,7 +16,7 @@ export const registerCommand = new Command("register")
|
|
|
16
16
|
network: Network.SEPOLIA,
|
|
17
17
|
signer,
|
|
18
18
|
});
|
|
19
|
-
const spinner = ora(`Registering agent "${opts.id}"
|
|
19
|
+
const spinner = ora(`Registering agent "${opts.id}"${walletHint()}...`).start();
|
|
20
20
|
const result = await client.registerAgent(opts.id, {
|
|
21
21
|
agentAddress: opts.agentWallet,
|
|
22
22
|
spendLimit: opts.spendLimit,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"register.js","sourceRoot":"","sources":["../../src/commands/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"register.js","sourceRoot":"","sources":["../../src/commands/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,OAAO,CAAC,UAAU,CAAC;KACnD,WAAW,CAAC,yCAAyC,CAAC;KACtD,cAAc,CAAC,gBAAgB,EAAE,oDAAoD,CAAC;KACtF,cAAc,CAAC,0BAA0B,EAAE,wBAAwB,CAAC;KACpE,cAAc,CAAC,uBAAuB,EAAE,oBAAoB,CAAC;KAC7D,MAAM,CAAC,0BAA0B,EAAE,0BAA0B,CAAC;KAC9D,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,GAAG,CAAC,sBAAsB,IAAI,CAAC,EAAE,IAAI,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;QAChF,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE;YACjD,YAAY,EAAE,IAAI,CAAC,WAAW;YAC9B,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,cAAc,EAAE,IAAI,CAAC,OAAO;SAC7B,CAAC,CAAC;QACH,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,IAAI,CAAC,EAAE,mBAAmB,IAAI,CAAC,EAAE,cAAc,CAAC,CAAC,CAAC;QACxF,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IACpF,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,0BAA0B,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAClE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
package/dist/commands/reject.js
CHANGED
|
@@ -2,12 +2,12 @@ import { Command } from "commander";
|
|
|
2
2
|
import chalk from "chalk";
|
|
3
3
|
import ora from "ora";
|
|
4
4
|
import { ENShell, Network } from "@enshell/sdk";
|
|
5
|
-
import { getSigner } from "../config.js";
|
|
5
|
+
import { getSigner, walletHint } from "../config.js";
|
|
6
6
|
export const rejectCommand = new Command("reject")
|
|
7
7
|
.description("Reject a queued action")
|
|
8
8
|
.requiredOption("--action-id <id>", "Queued action ID")
|
|
9
9
|
.action(async (opts) => {
|
|
10
|
-
const spinner = ora(
|
|
10
|
+
const spinner = ora(`Rejecting action${walletHint()}...`).start();
|
|
11
11
|
try {
|
|
12
12
|
const signer = await getSigner();
|
|
13
13
|
const client = new ENShell({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reject.js","sourceRoot":"","sources":["../../src/commands/reject.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"reject.js","sourceRoot":"","sources":["../../src/commands/reject.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,aAAa,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC;KAC/C,WAAW,CAAC,wBAAwB,CAAC;KACrC,cAAc,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;KACtD,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,mBAAmB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEpE,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,QAAQ,WAAW,CAAC,CAAC,CAAC;QAClE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,qBAAqB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC5D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
package/dist/commands/submit.js
CHANGED
|
@@ -3,7 +3,7 @@ import { keccak256, toUtf8Bytes } from "ethers";
|
|
|
3
3
|
import chalk from "chalk";
|
|
4
4
|
import ora from "ora";
|
|
5
5
|
import { ENShell, Network } from "@enshell/sdk";
|
|
6
|
-
import { getSigner } from "../config.js";
|
|
6
|
+
import { getSigner, walletHint } from "../config.js";
|
|
7
7
|
export const submitCommand = new Command("submit")
|
|
8
8
|
.description("Submit an action through the firewall (queued for CRE analysis)")
|
|
9
9
|
.requiredOption("--id <agentId>", "Agent identifier")
|
|
@@ -12,7 +12,7 @@ export const submitCommand = new Command("submit")
|
|
|
12
12
|
.option("--data <hex>", "Calldata (hex)", "0x")
|
|
13
13
|
.requiredOption("--instruction <text>", "Human-readable instruction")
|
|
14
14
|
.action(async (opts) => {
|
|
15
|
-
const spinner = ora(
|
|
15
|
+
const spinner = ora(`Submitting action${walletHint()}...`).start();
|
|
16
16
|
try {
|
|
17
17
|
const signer = await getSigner();
|
|
18
18
|
const client = new ENShell({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"submit.js","sourceRoot":"","sources":["../../src/commands/submit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"submit.js","sourceRoot":"","sources":["../../src/commands/submit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAErD,MAAM,CAAC,MAAM,aAAa,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC;KAC/C,WAAW,CAAC,iEAAiE,CAAC;KAC9E,cAAc,CAAC,gBAAgB,EAAE,kBAAkB,CAAC;KACpD,cAAc,CAAC,oBAAoB,EAAE,yBAAyB,CAAC;KAC/D,cAAc,CAAC,eAAe,EAAE,cAAc,CAAC;KAC/C,MAAM,CAAC,cAAc,EAAE,gBAAgB,EAAE,IAAI,CAAC;KAC9C,cAAc,CAAC,sBAAsB,EAAE,4BAA4B,CAAC;KACpE,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,OAAO,GAAG,GAAG,CAAC,oBAAoB,UAAU,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IAEnE,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC;YACzB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,eAAe,GAAG,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QAEjE,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,YAAY,CACtC,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,IAAI,EACT,eAAe,CAChB,CAAC;QAEF,OAAO,CAAC,OAAO,CACb,KAAK,CAAC,KAAK,CAAC,WAAW,MAAM,CAAC,QAAQ,0BAA0B,CAAC,CAClE,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,yCAAyC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IACpF,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,sBAAsB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAC7D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC"}
|
package/dist/config.d.ts
CHANGED
|
@@ -3,6 +3,8 @@ import { JsonRpcProvider, Signer } from "ethers";
|
|
|
3
3
|
import { WalletMode } from "./wallets/index.js";
|
|
4
4
|
export declare function setWalletMode(mode: WalletMode): void;
|
|
5
5
|
export declare function getWalletMode(): WalletMode;
|
|
6
|
+
/** Returns a hint string for commands when wallet approval is needed. */
|
|
7
|
+
export declare function walletHint(): string;
|
|
6
8
|
export declare function getProvider(): JsonRpcProvider;
|
|
7
9
|
export declare function getSigner(): Promise<Signer>;
|
|
8
10
|
export declare function getContractAddress(): string;
|
package/dist/config.js
CHANGED
|
@@ -10,8 +10,12 @@ export function setWalletMode(mode) {
|
|
|
10
10
|
export function getWalletMode() {
|
|
11
11
|
return _walletMode;
|
|
12
12
|
}
|
|
13
|
+
/** Returns a hint string for commands when wallet approval is needed. */
|
|
14
|
+
export function walletHint() {
|
|
15
|
+
return _walletMode === "walletconnect" ? " — approve in your wallet" : "";
|
|
16
|
+
}
|
|
13
17
|
export function getProvider() {
|
|
14
|
-
const rpcUrl = process.env.ENSHELL_RPC_URL || "https://rpc.
|
|
18
|
+
const rpcUrl = process.env.ENSHELL_RPC_URL || "https://ethereum-sepolia-rpc.publicnode.com";
|
|
15
19
|
return new JsonRpcProvider(rpcUrl);
|
|
16
20
|
}
|
|
17
21
|
export async function getSigner() {
|
|
@@ -20,7 +24,7 @@ export async function getSigner() {
|
|
|
20
24
|
export function getContractAddress() {
|
|
21
25
|
const addr = process.env.ENSHELL_CONTRACT_ADDRESS;
|
|
22
26
|
if (!addr)
|
|
23
|
-
return "
|
|
27
|
+
return "0x3886791bd82ff55294FaaEcCe3624A2376978dB2"; // Sepolia default
|
|
24
28
|
return addr;
|
|
25
29
|
}
|
|
26
30
|
/** Read-only contract instance (no signer needed). */
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAU,MAAM,QAAQ,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,aAAa,EAAc,MAAM,oBAAoB,CAAC;AAE/D,4DAA4D;AAC5D,IAAI,WAAW,GAAe,eAAe,CAAC;AAE9C,MAAM,UAAU,aAAa,CAAC,IAAgB;IAC5C,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,WAAW,CAAC;AACrB,CAAC;AAED,MAAM,UAAU,WAAW;IACzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAU,MAAM,QAAQ,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,aAAa,EAAc,MAAM,oBAAoB,CAAC;AAE/D,4DAA4D;AAC5D,IAAI,WAAW,GAAe,eAAe,CAAC;AAE9C,MAAM,UAAU,aAAa,CAAC,IAAgB;IAC5C,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,WAAW,CAAC;AACrB,CAAC;AAED,yEAAyE;AACzE,MAAM,UAAU,UAAU;IACxB,OAAO,WAAW,KAAK,eAAe,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC,EAAE,CAAC;AAC5E,CAAC;AAED,MAAM,UAAU,WAAW;IACzB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,6CAA6C,CAAC;IAC5F,OAAO,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS;IAC7B,OAAO,aAAa,CAAC,WAAW,CAAC,CAAC;AACpC,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC;IAClD,IAAI,CAAC,IAAI;QACP,OAAO,4CAA4C,CAAC,CAAC,kBAAkB;IACzE,OAAO,IAAI,CAAC;AACd,CAAC;AAED,sDAAsD;AACtD,MAAM,UAAU,WAAW;IACzB,OAAO,mBAAmB,CAAC,kBAAkB,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;AAClE,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
import { createRequire } from "node:module";
|
|
2
3
|
import { Command } from "commander";
|
|
3
4
|
import { setWalletMode } from "./config.js";
|
|
5
|
+
const require = createRequire(import.meta.url);
|
|
6
|
+
const pkg = require("../package.json");
|
|
4
7
|
import { registerCommand } from "./commands/register.js";
|
|
5
8
|
import { listCommand } from "./commands/list.js";
|
|
6
9
|
import { inspectCommand } from "./commands/inspect.js";
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import { rejectCommand } from "./commands/reject.js";
|
|
10
|
-
import { deactivateCommand } from "./commands/deactivate.js";
|
|
11
|
-
import { reactivateCommand } from "./commands/reactivate.js";
|
|
10
|
+
import { freezeCommand } from "./commands/freeze.js";
|
|
11
|
+
import { activateCommand } from "./commands/activate.js";
|
|
12
12
|
import { protectCommand } from "./commands/protect.js";
|
|
13
13
|
import { connectCommand } from "./commands/connect.js";
|
|
14
14
|
import { disconnectCommand } from "./commands/disconnect.js";
|
|
@@ -16,7 +16,7 @@ const program = new Command();
|
|
|
16
16
|
program
|
|
17
17
|
.name("enshell")
|
|
18
18
|
.description("CLI for ENShell on-chain AI agent firewall")
|
|
19
|
-
.version(
|
|
19
|
+
.version(pkg.version)
|
|
20
20
|
.option("--wallet <mode>", "Wallet mode: env (private key) or ledger (USB)")
|
|
21
21
|
.hook("preAction", (thisCommand) => {
|
|
22
22
|
const opts = thisCommand.opts();
|
|
@@ -29,11 +29,8 @@ program.addCommand(disconnectCommand);
|
|
|
29
29
|
program.addCommand(registerCommand);
|
|
30
30
|
program.addCommand(listCommand);
|
|
31
31
|
program.addCommand(inspectCommand);
|
|
32
|
-
program.addCommand(
|
|
33
|
-
program.addCommand(
|
|
34
|
-
program.addCommand(rejectCommand);
|
|
35
|
-
program.addCommand(deactivateCommand);
|
|
36
|
-
program.addCommand(reactivateCommand);
|
|
32
|
+
program.addCommand(freezeCommand);
|
|
33
|
+
program.addCommand(activateCommand);
|
|
37
34
|
program.addCommand(protectCommand);
|
|
38
35
|
program.parseAsync().then(() => process.exit(0));
|
|
39
36
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC/C,MAAM,GAAG,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;AAEvC,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAGvD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAE7D,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,SAAS,CAAC;KACf,WAAW,CAAC,4CAA4C,CAAC;KACzD,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;KACpB,MAAM,CACL,iBAAiB,EACjB,gDAAgD,CACjD;KACA,IAAI,CAAC,WAAW,EAAE,CAAC,WAAW,EAAE,EAAE;IACjC,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC;IAChC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,aAAa,CAAC,IAAI,CAAC,MAAoB,CAAC,CAAC;IAC3C,CAAC;AACH,CAAC,CAAC,CAAC;AAEL,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;AACnC,OAAO,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;AACtC,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;AACpC,OAAO,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;AAChC,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;AAEnC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;AAClC,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;AACpC,OAAO,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC;AAEnC,OAAO,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC"}
|
|
@@ -30,7 +30,7 @@ async function initProvider() {
|
|
|
30
30
|
optionalEvents: ["chainChanged", "accountsChanged"],
|
|
31
31
|
storage,
|
|
32
32
|
rpcMap: {
|
|
33
|
-
[SEPOLIA_CHAIN_ID]: process.env.ENSHELL_RPC_URL || "https://rpc.
|
|
33
|
+
[SEPOLIA_CHAIN_ID]: process.env.ENSHELL_RPC_URL || "https://ethereum-sepolia-rpc.publicnode.com",
|
|
34
34
|
},
|
|
35
35
|
});
|
|
36
36
|
return provider;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"walletconnect.js","sourceRoot":"","sources":["../../src/wallets/walletconnect.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,eAAe,EAAiB,MAAM,QAAQ,CAAC;AACxD,OAAO,MAAM,MAAM,iBAAiB,CAAC;AACrC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,MAAM,UAAU,GAAG,kCAAkC,CAAC;AACtD,MAAM,gBAAgB,GAAG,QAAQ,CAAC;AAElC,KAAK,UAAU,YAAY;IACzB,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAElC,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC;QAC3C,SAAS,EAAE,UAAU;QACrB,QAAQ,EAAE;YACR,IAAI,EAAE,aAAa;YACnB,WAAW,EAAE,iCAAiC;YAC9C,GAAG,EAAE,qBAAqB;YAC1B,KAAK,EAAE,CAAC,oDAAoD,CAAC;SAC9D;QACD,WAAW,EAAE,KAAK;QAClB,cAAc,EAAE,CAAC,gBAAgB,CAAC;QAClC,eAAe,EAAE;YACf,qBAAqB;YACrB,eAAe;YACf,sBAAsB;YACtB,cAAc;YACd,qBAAqB;YACrB,UAAU;YACV,gBAAgB;YAChB,qBAAqB;SACtB;QACD,cAAc,EAAE,CAAC,cAAc,EAAE,iBAAiB,CAAC;QACnD,OAAO;QACP,MAAM,EAAE;YACN,CAAC,gBAAgB,CAAC,EAChB,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,
|
|
1
|
+
{"version":3,"file":"walletconnect.js","sourceRoot":"","sources":["../../src/wallets/walletconnect.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@enshell/cli",
|
|
3
|
-
"version": "0.1.0-beta.
|
|
3
|
+
"version": "0.1.0-beta.17",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"bin": {
|
|
6
6
|
"enshell": "dist/index.js"
|
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
"prepublishOnly": "npm run build"
|
|
18
18
|
},
|
|
19
19
|
"dependencies": {
|
|
20
|
-
"@enshell/sdk": "^0.1.0-beta.
|
|
20
|
+
"@enshell/sdk": "^0.1.0-beta.17",
|
|
21
21
|
"@walletconnect/ethereum-provider": "^2.23.9",
|
|
22
22
|
"chalk": "^5.4.1",
|
|
23
23
|
"commander": "^14.0.0",
|