arc402-cli 1.0.0-rc.1 → 1.0.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 +41 -2
- package/dist/abis.d.ts +1 -0
- package/dist/abis.d.ts.map +1 -1
- package/dist/abis.js +29 -1
- package/dist/abis.js.map +1 -1
- package/dist/commands/backup.d.ts +3 -0
- package/dist/commands/backup.d.ts.map +1 -0
- package/dist/commands/backup.js +106 -0
- package/dist/commands/backup.js.map +1 -0
- package/dist/commands/compute.d.ts +14 -0
- package/dist/commands/compute.d.ts.map +1 -0
- package/dist/commands/compute.js +466 -0
- package/dist/commands/compute.js.map +1 -0
- package/dist/commands/config.d.ts.map +1 -1
- package/dist/commands/config.js +11 -1
- package/dist/commands/config.js.map +1 -1
- package/dist/commands/daemon.d.ts.map +1 -1
- package/dist/commands/daemon.js +67 -0
- package/dist/commands/daemon.js.map +1 -1
- package/dist/commands/discover.d.ts.map +1 -1
- package/dist/commands/discover.js +60 -15
- package/dist/commands/discover.js.map +1 -1
- package/dist/commands/doctor.d.ts +3 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +205 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/wallet.d.ts.map +1 -1
- package/dist/commands/wallet.js +299 -65
- package/dist/commands/wallet.js.map +1 -1
- package/dist/commands/watch.d.ts.map +1 -1
- package/dist/commands/watch.js +146 -9
- package/dist/commands/watch.js.map +1 -1
- package/dist/commands/workroom.d.ts.map +1 -1
- package/dist/commands/workroom.js +112 -6
- package/dist/commands/workroom.js.map +1 -1
- package/dist/config.d.ts +12 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +41 -4
- package/dist/config.js.map +1 -1
- package/dist/daemon/compute-metering.d.ts +61 -0
- package/dist/daemon/compute-metering.d.ts.map +1 -0
- package/dist/daemon/compute-metering.js +299 -0
- package/dist/daemon/compute-metering.js.map +1 -0
- package/dist/daemon/compute-session.d.ts +100 -0
- package/dist/daemon/compute-session.d.ts.map +1 -0
- package/dist/daemon/compute-session.js +231 -0
- package/dist/daemon/compute-session.js.map +1 -0
- package/dist/daemon/config.d.ts +33 -1
- package/dist/daemon/config.d.ts.map +1 -1
- package/dist/daemon/config.js +69 -0
- package/dist/daemon/config.js.map +1 -1
- package/dist/daemon/credentials.d.ts +24 -0
- package/dist/daemon/credentials.d.ts.map +1 -0
- package/dist/daemon/credentials.js +80 -0
- package/dist/daemon/credentials.js.map +1 -0
- package/dist/daemon/delivery-client.d.ts +35 -0
- package/dist/daemon/delivery-client.d.ts.map +1 -0
- package/dist/daemon/delivery-client.js +231 -0
- package/dist/daemon/delivery-client.js.map +1 -0
- package/dist/daemon/file-delivery.d.ts +98 -0
- package/dist/daemon/file-delivery.d.ts.map +1 -0
- package/dist/daemon/file-delivery.js +461 -0
- package/dist/daemon/file-delivery.js.map +1 -0
- package/dist/daemon/index.d.ts +1 -0
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +793 -227
- package/dist/daemon/index.js.map +1 -1
- package/dist/daemon/notify.d.ts +35 -6
- package/dist/daemon/notify.d.ts.map +1 -1
- package/dist/daemon/notify.js +176 -48
- package/dist/daemon/notify.js.map +1 -1
- package/dist/daemon/worker-executor.d.ts +71 -0
- package/dist/daemon/worker-executor.d.ts.map +1 -0
- package/dist/daemon/worker-executor.js +382 -0
- package/dist/daemon/worker-executor.js.map +1 -0
- package/dist/drain-v4.js +2 -2
- package/dist/drain-v4.js.map +1 -1
- package/dist/endpoint-notify.d.ts +9 -1
- package/dist/endpoint-notify.d.ts.map +1 -1
- package/dist/endpoint-notify.js +116 -3
- package/dist/endpoint-notify.js.map +1 -1
- package/dist/index.js +81 -1
- package/dist/index.js.map +1 -1
- package/dist/program.d.ts.map +1 -1
- package/dist/program.js +6 -0
- package/dist/program.js.map +1 -1
- package/dist/repl.d.ts.map +1 -1
- package/dist/repl.js +69 -486
- package/dist/repl.js.map +1 -1
- package/dist/tui/App.d.ts +12 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +154 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/Footer.d.ts +11 -0
- package/dist/tui/Footer.d.ts.map +1 -0
- package/dist/tui/Footer.js +13 -0
- package/dist/tui/Footer.js.map +1 -0
- package/dist/tui/Header.d.ts +14 -0
- package/dist/tui/Header.d.ts.map +1 -0
- package/dist/tui/Header.js +19 -0
- package/dist/tui/Header.js.map +1 -0
- package/dist/tui/InputLine.d.ts +11 -0
- package/dist/tui/InputLine.d.ts.map +1 -0
- package/dist/tui/InputLine.js +145 -0
- package/dist/tui/InputLine.js.map +1 -0
- package/dist/tui/Viewport.d.ts +14 -0
- package/dist/tui/Viewport.d.ts.map +1 -0
- package/dist/tui/Viewport.js +48 -0
- package/dist/tui/Viewport.js.map +1 -0
- package/dist/tui/WalletConnectPairing.d.ts +23 -0
- package/dist/tui/WalletConnectPairing.d.ts.map +1 -0
- package/dist/tui/WalletConnectPairing.js +61 -0
- package/dist/tui/WalletConnectPairing.js.map +1 -0
- package/dist/tui/components/Button.d.ts +7 -0
- package/dist/tui/components/Button.d.ts.map +1 -0
- package/dist/tui/components/Button.js +21 -0
- package/dist/tui/components/Button.js.map +1 -0
- package/dist/tui/components/CeremonyView.d.ts +13 -0
- package/dist/tui/components/CeremonyView.d.ts.map +1 -0
- package/dist/tui/components/CeremonyView.js +10 -0
- package/dist/tui/components/CeremonyView.js.map +1 -0
- package/dist/tui/components/CompletionDropdown.d.ts +7 -0
- package/dist/tui/components/CompletionDropdown.d.ts.map +1 -0
- package/dist/tui/components/CompletionDropdown.js +23 -0
- package/dist/tui/components/CompletionDropdown.js.map +1 -0
- package/dist/tui/components/ConfirmPrompt.d.ts +9 -0
- package/dist/tui/components/ConfirmPrompt.d.ts.map +1 -0
- package/dist/tui/components/ConfirmPrompt.js +10 -0
- package/dist/tui/components/ConfirmPrompt.js.map +1 -0
- package/dist/tui/components/CustomTextInput.d.ts +15 -0
- package/dist/tui/components/CustomTextInput.d.ts.map +1 -0
- package/dist/tui/components/CustomTextInput.js +99 -0
- package/dist/tui/components/CustomTextInput.js.map +1 -0
- package/dist/tui/components/InteractiveTable.d.ts +14 -0
- package/dist/tui/components/InteractiveTable.d.ts.map +1 -0
- package/dist/tui/components/InteractiveTable.js +61 -0
- package/dist/tui/components/InteractiveTable.js.map +1 -0
- package/dist/tui/components/StepSpinner.d.ts +11 -0
- package/dist/tui/components/StepSpinner.d.ts.map +1 -0
- package/dist/tui/components/StepSpinner.js +32 -0
- package/dist/tui/components/StepSpinner.js.map +1 -0
- package/dist/tui/components/Toast.d.ts +18 -0
- package/dist/tui/components/Toast.d.ts.map +1 -0
- package/dist/tui/components/Toast.js +29 -0
- package/dist/tui/components/Toast.js.map +1 -0
- package/dist/tui/index.d.ts +2 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js +55 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/tui/useChat.d.ts +11 -0
- package/dist/tui/useChat.d.ts.map +1 -0
- package/dist/tui/useChat.js +91 -0
- package/dist/tui/useChat.js.map +1 -0
- package/dist/tui/useCommand.d.ts +12 -0
- package/dist/tui/useCommand.d.ts.map +1 -0
- package/dist/tui/useCommand.js +137 -0
- package/dist/tui/useCommand.js.map +1 -0
- package/dist/tui/useNotifications.d.ts +9 -0
- package/dist/tui/useNotifications.d.ts.map +1 -0
- package/dist/tui/useNotifications.js +17 -0
- package/dist/tui/useNotifications.js.map +1 -0
- package/dist/tui/useScroll.d.ts +17 -0
- package/dist/tui/useScroll.d.ts.map +1 -0
- package/dist/tui/useScroll.js +46 -0
- package/dist/tui/useScroll.js.map +1 -0
- package/dist/ui/format.d.ts.map +1 -1
- package/dist/ui/format.js +2 -0
- package/dist/ui/format.js.map +1 -1
- package/dist/ui/qr-render.d.ts +25 -0
- package/dist/ui/qr-render.d.ts.map +1 -0
- package/dist/ui/qr-render.js +90 -0
- package/dist/ui/qr-render.js.map +1 -0
- package/dist/ui/rpc-fallback.d.ts +11 -0
- package/dist/ui/rpc-fallback.d.ts.map +1 -0
- package/dist/ui/rpc-fallback.js +58 -0
- package/dist/ui/rpc-fallback.js.map +1 -0
- package/dist/walletconnect.d.ts +4 -0
- package/dist/walletconnect.d.ts.map +1 -1
- package/dist/walletconnect.js.map +1 -1
- package/package.json +10 -2
- package/scripts/authorize-machine-key.ts +0 -43
- package/scripts/drain-wallet.ts +0 -149
- package/scripts/execute-spend-only.ts +0 -81
- package/scripts/register-agent-userop.ts +0 -186
- package/src/abis.ts +0 -187
- package/src/bundler.ts +0 -235
- package/src/client.ts +0 -36
- package/src/coinbase-smart-wallet.ts +0 -51
- package/src/commands/accept.ts +0 -64
- package/src/commands/agent-handshake.ts +0 -72
- package/src/commands/agent.ts +0 -691
- package/src/commands/agreements.ts +0 -350
- package/src/commands/arbitrator.ts +0 -180
- package/src/commands/arena-handshake.ts +0 -257
- package/src/commands/arena.ts +0 -122
- package/src/commands/cancel.ts +0 -35
- package/src/commands/channel.ts +0 -218
- package/src/commands/coldstart.ts +0 -165
- package/src/commands/config.ts +0 -58
- package/src/commands/contract-interaction.ts +0 -166
- package/src/commands/daemon.ts +0 -978
- package/src/commands/deliver.ts +0 -148
- package/src/commands/discover.ts +0 -297
- package/src/commands/dispute.ts +0 -375
- package/src/commands/endpoint.ts +0 -620
- package/src/commands/feed.ts +0 -229
- package/src/commands/hire.ts +0 -245
- package/src/commands/migrate.ts +0 -177
- package/src/commands/negotiate.ts +0 -271
- package/src/commands/openshell.ts +0 -1055
- package/src/commands/owner.ts +0 -35
- package/src/commands/policy.ts +0 -263
- package/src/commands/relay.ts +0 -273
- package/src/commands/remediate.ts +0 -24
- package/src/commands/reputation.ts +0 -79
- package/src/commands/setup.ts +0 -343
- package/src/commands/trust.ts +0 -27
- package/src/commands/verify.ts +0 -91
- package/src/commands/wallet.ts +0 -3280
- package/src/commands/watch.ts +0 -23
- package/src/commands/watchtower.ts +0 -248
- package/src/commands/workroom.ts +0 -959
- package/src/config.ts +0 -174
- package/src/daemon/config.ts +0 -308
- package/src/daemon/hire-listener.ts +0 -226
- package/src/daemon/index.ts +0 -955
- package/src/daemon/job-lifecycle.ts +0 -215
- package/src/daemon/notify.ts +0 -157
- package/src/daemon/token-metering.ts +0 -183
- package/src/daemon/userops.ts +0 -119
- package/src/daemon/wallet-monitor.ts +0 -90
- package/src/drain-v4.ts +0 -159
- package/src/endpoint-config.ts +0 -83
- package/src/endpoint-notify.ts +0 -46
- package/src/index.ts +0 -26
- package/src/openshell-runtime.ts +0 -277
- package/src/program.ts +0 -83
- package/src/repl.ts +0 -680
- package/src/signing.ts +0 -28
- package/src/telegram-notify.ts +0 -88
- package/src/ui/banner.ts +0 -51
- package/src/ui/colors.ts +0 -30
- package/src/ui/format.ts +0 -77
- package/src/ui/spinner.ts +0 -56
- package/src/ui/tree.ts +0 -16
- package/src/utils/format.ts +0 -48
- package/src/utils/hash.ts +0 -5
- package/src/utils/time.ts +0 -15
- package/src/wallet-router.ts +0 -178
- package/src/walletconnect-session.ts +0 -27
- package/src/walletconnect.ts +0 -294
- package/test/time.test.js +0 -11
- package/tsconfig.json +0 -19
|
@@ -1,165 +0,0 @@
|
|
|
1
|
-
import { Command } from "commander";
|
|
2
|
-
import { ethers } from "ethers";
|
|
3
|
-
import { loadConfig } from "../config";
|
|
4
|
-
import { getClient, requireSigner } from "../client";
|
|
5
|
-
import { c } from '../ui/colors';
|
|
6
|
-
import { startSpinner } from '../ui/spinner';
|
|
7
|
-
import { renderTree } from '../ui/tree';
|
|
8
|
-
|
|
9
|
-
const VOUCHING_REGISTRY_ABI = [
|
|
10
|
-
"function vouch(address newAgent, uint256 stakeAmount) external payable",
|
|
11
|
-
"function getVouchedBoost(address agent) external view returns (uint256)",
|
|
12
|
-
"function getVoucher(address agent) external view returns (address)",
|
|
13
|
-
] as const;
|
|
14
|
-
|
|
15
|
-
const TRUST_REGISTRY_BOND_ABI = [
|
|
16
|
-
"function postBond() external payable",
|
|
17
|
-
"function claimBond() external",
|
|
18
|
-
"function getBondInfo(address agent) external view returns (uint256 amount, uint256 postedAt, bool active)",
|
|
19
|
-
] as const;
|
|
20
|
-
|
|
21
|
-
const BOND_DEFAULT_AMOUNT = ethers.parseEther("0.01");
|
|
22
|
-
const BOND_LOCK_SECONDS = 90 * 24 * 60 * 60; // 90 days
|
|
23
|
-
|
|
24
|
-
export function registerColdStartCommands(program: Command): void {
|
|
25
|
-
// ─── vouch ─────────────────────────────────────────────────────────────────
|
|
26
|
-
|
|
27
|
-
program
|
|
28
|
-
.command("vouch <address>")
|
|
29
|
-
.description("Stake-backed introduction for a new agent (cold start boost)")
|
|
30
|
-
.option("--stake <wei>", "Amount to stake in wei (default: 0)")
|
|
31
|
-
.option("--signer <key>", "Private key override (hex, 0x-prefixed)")
|
|
32
|
-
.option("--json")
|
|
33
|
-
.action(async (address, opts) => {
|
|
34
|
-
const config = loadConfig();
|
|
35
|
-
if (!config.vouchingRegistryAddress) {
|
|
36
|
-
console.error("vouchingRegistryAddress not configured. Run `arc402 config set vouchingRegistryAddress <address>`.");
|
|
37
|
-
process.exit(1);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
let { signer, provider } = await requireSigner(config);
|
|
41
|
-
if (opts.signer) {
|
|
42
|
-
signer = new ethers.Wallet(opts.signer, provider);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const stakeAmount = opts.stake ? BigInt(opts.stake) : 0n;
|
|
46
|
-
const contract = new ethers.Contract(config.vouchingRegistryAddress, VOUCHING_REGISTRY_ABI, signer);
|
|
47
|
-
|
|
48
|
-
const spinner = startSpinner(`Vouching for ${address}…`);
|
|
49
|
-
const tx = await contract.vouch(address, stakeAmount);
|
|
50
|
-
const receipt = await tx.wait();
|
|
51
|
-
|
|
52
|
-
const boost = await contract.getVouchedBoost(address);
|
|
53
|
-
|
|
54
|
-
const payload = {
|
|
55
|
-
newAgent: address,
|
|
56
|
-
stakeAmount: stakeAmount.toString(),
|
|
57
|
-
boostGranted: boost.toString(),
|
|
58
|
-
txHash: receipt.hash,
|
|
59
|
-
};
|
|
60
|
-
if (opts.json) { spinner.stop(); return console.log(JSON.stringify(payload, null, 2)); }
|
|
61
|
-
spinner.succeed(` Vouched — ${address}`);
|
|
62
|
-
renderTree([
|
|
63
|
-
{ label: 'New Agent', value: address },
|
|
64
|
-
{ label: 'Stake', value: stakeAmount > 0n ? `${ethers.formatEther(stakeAmount)} ETH` : '0' },
|
|
65
|
-
{ label: 'Boost', value: `+${boost} trust points` },
|
|
66
|
-
{ label: 'Tx', value: receipt.hash, last: true },
|
|
67
|
-
]);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
// ─── bond ──────────────────────────────────────────────────────────────────
|
|
71
|
-
|
|
72
|
-
const bond = program
|
|
73
|
-
.command("bond")
|
|
74
|
-
.description("Bonded-entry cold start: post 0.01 ETH bond for trust boost, or claim after 90 days")
|
|
75
|
-
.option("--amount <wei>", `Bond amount in wei (default: ${BOND_DEFAULT_AMOUNT})`)
|
|
76
|
-
.option("--claim", "Claim bond after 90-day lock period")
|
|
77
|
-
.option("--json")
|
|
78
|
-
.action(async (opts) => {
|
|
79
|
-
const config = loadConfig();
|
|
80
|
-
if (!config.trustRegistryAddress) {
|
|
81
|
-
console.error("trustRegistryAddress not configured.");
|
|
82
|
-
process.exit(1);
|
|
83
|
-
}
|
|
84
|
-
const { signer } = await requireSigner(config);
|
|
85
|
-
const contract = new ethers.Contract(config.trustRegistryAddress, TRUST_REGISTRY_BOND_ABI, signer);
|
|
86
|
-
|
|
87
|
-
if (opts.claim) {
|
|
88
|
-
const tx = await contract.claimBond();
|
|
89
|
-
const receipt = await tx.wait();
|
|
90
|
-
const payload = { claimed: true, txHash: receipt.hash };
|
|
91
|
-
if (opts.json) return console.log(JSON.stringify(payload, null, 2));
|
|
92
|
-
console.log(`bond claimed`);
|
|
93
|
-
console.log(` tx: ${receipt.hash}`);
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
const amount = opts.amount ? BigInt(opts.amount) : BOND_DEFAULT_AMOUNT;
|
|
98
|
-
const bondSpinner = startSpinner('Posting bond…');
|
|
99
|
-
const tx = await contract.postBond({ value: amount });
|
|
100
|
-
const receipt = await tx.wait();
|
|
101
|
-
|
|
102
|
-
const payload = { bonded: true, amount: amount.toString(), txHash: receipt.hash };
|
|
103
|
-
if (opts.json) { bondSpinner.stop(); return console.log(JSON.stringify(payload, null, 2)); }
|
|
104
|
-
bondSpinner.succeed(` Bond posted — ${ethers.formatEther(amount)} ETH`);
|
|
105
|
-
renderTree([
|
|
106
|
-
{ label: 'Amount', value: `${ethers.formatEther(amount)} ETH` },
|
|
107
|
-
{ label: 'Tx', value: receipt.hash },
|
|
108
|
-
{ label: 'Note', value: 'Claimable after 90 days of clean operation', last: true },
|
|
109
|
-
]);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
// arc402 bond status <address>
|
|
113
|
-
bond
|
|
114
|
-
.command("status <address>")
|
|
115
|
-
.description("Show active bond and time remaining for an address")
|
|
116
|
-
.option("--json")
|
|
117
|
-
.action(async (address, opts) => {
|
|
118
|
-
const config = loadConfig();
|
|
119
|
-
if (!config.trustRegistryAddress) {
|
|
120
|
-
console.error("trustRegistryAddress not configured.");
|
|
121
|
-
process.exit(1);
|
|
122
|
-
}
|
|
123
|
-
const { provider } = await getClient(config);
|
|
124
|
-
const contract = new ethers.Contract(config.trustRegistryAddress, TRUST_REGISTRY_BOND_ABI, provider);
|
|
125
|
-
|
|
126
|
-
let amount: bigint, postedAt: bigint, active: boolean;
|
|
127
|
-
try {
|
|
128
|
-
const result = await contract.getBondInfo(address);
|
|
129
|
-
amount = result.amount;
|
|
130
|
-
postedAt = result.postedAt;
|
|
131
|
-
active = result.active;
|
|
132
|
-
} catch {
|
|
133
|
-
const payload = { address, bonded: false };
|
|
134
|
-
if (opts.json) return console.log(JSON.stringify(payload, null, 2));
|
|
135
|
-
console.log('\n ' + c.mark + c.white(` Bond Status — ${address}`));
|
|
136
|
-
renderTree([{ label: 'Status', value: 'No active bond', last: true }]);
|
|
137
|
-
return;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
const now = Math.floor(Date.now() / 1000);
|
|
141
|
-
const claimableAt = Number(postedAt) + BOND_LOCK_SECONDS;
|
|
142
|
-
const secondsRemaining = Math.max(0, claimableAt - now);
|
|
143
|
-
const daysRemaining = Math.ceil(secondsRemaining / 86400);
|
|
144
|
-
|
|
145
|
-
const payload = {
|
|
146
|
-
address,
|
|
147
|
-
bonded: active,
|
|
148
|
-
amount: amount.toString(),
|
|
149
|
-
postedAt: new Date(Number(postedAt) * 1000).toISOString(),
|
|
150
|
-
claimableAt: new Date(claimableAt * 1000).toISOString(),
|
|
151
|
-
daysRemaining,
|
|
152
|
-
};
|
|
153
|
-
if (opts.json) return console.log(JSON.stringify(payload, null, 2));
|
|
154
|
-
console.log('\n ' + c.mark + c.white(` Bond Status — ${address}`));
|
|
155
|
-
if (!active) {
|
|
156
|
-
renderTree([{ label: 'Status', value: 'No active bond', last: true }]);
|
|
157
|
-
return;
|
|
158
|
-
}
|
|
159
|
-
renderTree([
|
|
160
|
-
{ label: 'Amount', value: `${ethers.formatEther(amount)} ETH` },
|
|
161
|
-
{ label: 'Posted', value: new Date(Number(postedAt) * 1000).toISOString() },
|
|
162
|
-
{ label: 'Claimable', value: daysRemaining > 0 ? `in ${daysRemaining} days` : 'now', last: true },
|
|
163
|
-
]);
|
|
164
|
-
});
|
|
165
|
-
}
|
package/src/commands/config.ts
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import { Command } from "commander";
|
|
2
|
-
import prompts from "prompts";
|
|
3
|
-
import chalk from "chalk";
|
|
4
|
-
import { Arc402Config, NETWORK_DEFAULTS, configExists, loadConfig, saveConfig, getSubdomainApi } from "../config";
|
|
5
|
-
import { c } from '../ui/colors';
|
|
6
|
-
|
|
7
|
-
export function registerConfigCommands(program: Command): void {
|
|
8
|
-
const config = program.command("config").description("Manage ARC-402 CLI configuration");
|
|
9
|
-
config.command("init").description("Interactive setup for ~/.arc402/config.json").action(async () => {
|
|
10
|
-
const existing: Partial<Arc402Config> = configExists() ? loadConfig() : {};
|
|
11
|
-
const answers = await prompts([
|
|
12
|
-
{ type: "select", name: "network", message: "Network", choices: [{ title: "Base Mainnet", value: "base-mainnet" }, { title: "Base Sepolia (testnet)", value: "base-sepolia" }], initial: existing.network === "base-sepolia" ? 1 : 0 },
|
|
13
|
-
]);
|
|
14
|
-
|
|
15
|
-
if (!answers.network) { console.log(chalk.red("✗ Setup cancelled")); return; }
|
|
16
|
-
|
|
17
|
-
const defaults = NETWORK_DEFAULTS[answers.network] ?? {};
|
|
18
|
-
const cfg: Arc402Config = {
|
|
19
|
-
network: answers.network,
|
|
20
|
-
walletConnectProjectId: "455e9425343b9156fce1428250c9a54a",
|
|
21
|
-
rpcUrl: defaults.rpcUrl ?? "https://mainnet.base.org",
|
|
22
|
-
trustRegistryAddress: defaults.trustRegistryAddress ?? "",
|
|
23
|
-
agentRegistryAddress: defaults.agentRegistryV2Address ?? defaults.agentRegistryAddress,
|
|
24
|
-
serviceAgreementAddress: defaults.serviceAgreementAddress,
|
|
25
|
-
reputationOracleAddress: defaults.reputationOracleAddress,
|
|
26
|
-
sponsorshipAttestationAddress: defaults.sponsorshipAttestationAddress,
|
|
27
|
-
capabilityRegistryAddress: defaults.capabilityRegistryAddress,
|
|
28
|
-
governanceAddress: defaults.governanceAddress,
|
|
29
|
-
...(existing.privateKey ? { privateKey: existing.privateKey } : {}),
|
|
30
|
-
...(existing.subdomainApi ? { subdomainApi: existing.subdomainApi } : {}),
|
|
31
|
-
...(existing.telegramBotToken ? { telegramBotToken: existing.telegramBotToken } : {}),
|
|
32
|
-
...(existing.telegramChatId ? { telegramChatId: existing.telegramChatId } : {}),
|
|
33
|
-
...(existing.telegramThreadId ? { telegramThreadId: existing.telegramThreadId } : {}),
|
|
34
|
-
...(existing.walletContractAddress ? { walletContractAddress: existing.walletContractAddress } : {}),
|
|
35
|
-
};
|
|
36
|
-
saveConfig(cfg);
|
|
37
|
-
|
|
38
|
-
console.log();
|
|
39
|
-
console.log(' ' + c.success + c.white(' Config saved'));
|
|
40
|
-
console.log();
|
|
41
|
-
console.log(chalk.dim(" Network ") + chalk.white(answers.network === "base-mainnet" ? "Base Mainnet" : "Base Sepolia"));
|
|
42
|
-
console.log(chalk.dim(" RPC ") + chalk.white(cfg.rpcUrl!));
|
|
43
|
-
console.log(chalk.dim(" Contracts ") + chalk.white("All protocol addresses loaded"));
|
|
44
|
-
console.log();
|
|
45
|
-
console.log(chalk.dim(" Next: ") + chalk.white("arc402 wallet deploy"));
|
|
46
|
-
console.log();
|
|
47
|
-
});
|
|
48
|
-
config.command("show").description("Print current config").action(() => {
|
|
49
|
-
const cfg = loadConfig();
|
|
50
|
-
console.log(JSON.stringify({ ...cfg, privateKey: cfg.privateKey ? "***" : undefined, subdomainApi: getSubdomainApi(cfg) }, null, 2));
|
|
51
|
-
});
|
|
52
|
-
config.command("set <key> <value>").description("Set a config value: arc402 config set <key> <value>").action((key: string, value: string) => {
|
|
53
|
-
const cfg = loadConfig();
|
|
54
|
-
(cfg as unknown as Record<string, unknown>)[key] = value;
|
|
55
|
-
saveConfig(cfg);
|
|
56
|
-
console.log(' ' + c.success + c.white(` ${key} = ${value}`));
|
|
57
|
-
});
|
|
58
|
-
}
|
|
@@ -1,166 +0,0 @@
|
|
|
1
|
-
import { Command } from "commander";
|
|
2
|
-
import { ethers } from "ethers";
|
|
3
|
-
import { loadConfig } from "../config";
|
|
4
|
-
import { requireSigner } from "../client";
|
|
5
|
-
import { ContractInteractionClient, IntentPayload } from "@arc402/sdk";
|
|
6
|
-
|
|
7
|
-
export function registerContractInteractionCommands(program: Command): void {
|
|
8
|
-
const contract = program.command("contract").description("Direct contract interaction via ARC402Wallet");
|
|
9
|
-
|
|
10
|
-
contract
|
|
11
|
-
.command("call <target> <method> [args...]")
|
|
12
|
-
.description("Build, attest, and optionally execute an arbitrary contract call")
|
|
13
|
-
.option("--abi <json>", "ABI fragment array as JSON string, e.g. '[\"function swap(...)\"]'")
|
|
14
|
-
.option("--value <wei>", "ETH value to send with the call (in wei)", "0")
|
|
15
|
-
.option("--min-return <value>", "Minimum return value for slippage guard", "0")
|
|
16
|
-
.option("--approval-token <address>", "ERC-20 token to approve before call", ethers.ZeroAddress)
|
|
17
|
-
.option("--approval-amount <value>", "Max ERC-20 approval for this call (in token units)", "0")
|
|
18
|
-
.option("--with-agreement <id>", "Execute under ServiceAgreement escrow (requires walletContractAddress in config)")
|
|
19
|
-
.option("--attest", "Create intent attestation before executing (requires intentAttestationAddress in config)")
|
|
20
|
-
.option("--dry-run", "Build and print the encoded payload without executing")
|
|
21
|
-
.option("--json", "Output as JSON")
|
|
22
|
-
.action(async (target: string, method: string, rawArgs: string[], opts) => {
|
|
23
|
-
const config = loadConfig();
|
|
24
|
-
const { signer, address } = await requireSigner(config);
|
|
25
|
-
|
|
26
|
-
// Parse ABI — accept a JSON array of ABI fragments, or construct a minimal one
|
|
27
|
-
let abi: string[];
|
|
28
|
-
if (opts.abi) {
|
|
29
|
-
try {
|
|
30
|
-
abi = JSON.parse(opts.abi) as string[];
|
|
31
|
-
} catch {
|
|
32
|
-
console.error("--abi must be a valid JSON array of ABI fragments");
|
|
33
|
-
process.exit(1);
|
|
34
|
-
}
|
|
35
|
-
} else {
|
|
36
|
-
// Construct a minimal ABI fragment for the method with inferred arg types
|
|
37
|
-
const argTypes = rawArgs.map(() => "bytes32").join(", ");
|
|
38
|
-
abi = [`function ${method}(${argTypes})`];
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
// Parse args — attempt JSON parsing for each arg (handles numbers, arrays, objects)
|
|
42
|
-
const parsedArgs = rawArgs.map((a) => {
|
|
43
|
-
try {
|
|
44
|
-
return JSON.parse(a);
|
|
45
|
-
} catch {
|
|
46
|
-
return a;
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
const intentAttestationAddress = config.intentAttestationAddress;
|
|
51
|
-
if (!intentAttestationAddress) {
|
|
52
|
-
console.error("intentAttestationAddress missing in config");
|
|
53
|
-
process.exit(1);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
const client = new ContractInteractionClient(intentAttestationAddress, signer, address);
|
|
57
|
-
|
|
58
|
-
let payload: IntentPayload;
|
|
59
|
-
try {
|
|
60
|
-
payload = client.buildContractCall(target, abi, method, parsedArgs, {
|
|
61
|
-
value: BigInt(opts.value),
|
|
62
|
-
minReturnValue: BigInt(opts.minReturn),
|
|
63
|
-
maxApprovalAmount: BigInt(opts.approvalAmount),
|
|
64
|
-
approvalToken: opts.approvalToken,
|
|
65
|
-
});
|
|
66
|
-
} catch (err) {
|
|
67
|
-
console.error(`Failed to encode call: ${err instanceof Error ? err.message : String(err)}`);
|
|
68
|
-
process.exit(1);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
if (opts.dryRun || (!opts.withAgreement && !opts.attest)) {
|
|
72
|
-
if (opts.json) {
|
|
73
|
-
console.log(JSON.stringify({
|
|
74
|
-
target: payload.target,
|
|
75
|
-
data: payload.data,
|
|
76
|
-
value: payload.value.toString(),
|
|
77
|
-
minReturnValue: payload.minReturnValue.toString(),
|
|
78
|
-
maxApprovalAmount: payload.maxApprovalAmount.toString(),
|
|
79
|
-
approvalToken: payload.approvalToken,
|
|
80
|
-
}, null, 2));
|
|
81
|
-
} else {
|
|
82
|
-
console.log(`target: ${payload.target}`);
|
|
83
|
-
console.log(`method: ${method}`);
|
|
84
|
-
console.log(`calldata: ${payload.data}`);
|
|
85
|
-
console.log(`value: ${payload.value} wei`);
|
|
86
|
-
console.log(`minReturnValue: ${payload.minReturnValue}`);
|
|
87
|
-
console.log(`approvalToken: ${payload.approvalToken}`);
|
|
88
|
-
console.log(`maxApprovalAmount:${payload.maxApprovalAmount}`);
|
|
89
|
-
}
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
// Attest intent before execution if requested
|
|
94
|
-
let attestationId: string | undefined;
|
|
95
|
-
if (opts.attest) {
|
|
96
|
-
console.log("Creating intent attestation…");
|
|
97
|
-
try {
|
|
98
|
-
const attestation = await client.signAndAttestContractCall(payload, signer);
|
|
99
|
-
attestationId = attestation.attestationId;
|
|
100
|
-
console.log(`attestationId: ${attestationId}`);
|
|
101
|
-
} catch (err) {
|
|
102
|
-
console.error(`Attestation failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
103
|
-
process.exit(1);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// Execute under agreement escrow
|
|
108
|
-
if (opts.withAgreement !== undefined) {
|
|
109
|
-
if (!config.walletContractAddress) {
|
|
110
|
-
console.error("walletContractAddress missing in config — required for --with-agreement");
|
|
111
|
-
process.exit(1);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
console.log(`Executing contract call under agreement ${opts.withAgreement}…`);
|
|
115
|
-
try {
|
|
116
|
-
const tx = await client.executeWithEscrow(config.walletContractAddress, payload, signer);
|
|
117
|
-
const receipt = await tx.wait();
|
|
118
|
-
|
|
119
|
-
if (opts.json) {
|
|
120
|
-
console.log(JSON.stringify({
|
|
121
|
-
txHash: receipt!.hash,
|
|
122
|
-
status: receipt!.status === 1 ? "success" : "reverted",
|
|
123
|
-
blockNumber: receipt!.blockNumber,
|
|
124
|
-
...(attestationId ? { attestationId } : {}),
|
|
125
|
-
}, null, 2));
|
|
126
|
-
} else {
|
|
127
|
-
console.log(`tx: ${receipt!.hash}`);
|
|
128
|
-
console.log(`block: ${receipt!.blockNumber}`);
|
|
129
|
-
console.log(`status: ${receipt!.status === 1 ? "success" : "reverted"}`);
|
|
130
|
-
if (attestationId) console.log(`attestationId: ${attestationId}`);
|
|
131
|
-
}
|
|
132
|
-
} catch (err) {
|
|
133
|
-
console.error(`Execution failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
134
|
-
process.exit(1);
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
contract
|
|
140
|
-
.command("verify <txHash>")
|
|
141
|
-
.description("Verify the result of a previously submitted contract call")
|
|
142
|
-
.option("--expected <hex>", "Expected return data (hex) to verify against")
|
|
143
|
-
.option("--json")
|
|
144
|
-
.action(async (txHash: string, opts) => {
|
|
145
|
-
const config = loadConfig();
|
|
146
|
-
const { signer, address } = await requireSigner(config);
|
|
147
|
-
|
|
148
|
-
const intentAttestationAddress = config.intentAttestationAddress;
|
|
149
|
-
if (!intentAttestationAddress) {
|
|
150
|
-
console.error("intentAttestationAddress missing in config");
|
|
151
|
-
process.exit(1);
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
const client = new ContractInteractionClient(intentAttestationAddress, signer, address);
|
|
155
|
-
const result = await client.verifyContractCallResult(txHash, opts.expected);
|
|
156
|
-
|
|
157
|
-
if (opts.json) {
|
|
158
|
-
console.log(JSON.stringify(result, null, 2));
|
|
159
|
-
} else {
|
|
160
|
-
console.log(`txHash: ${result.txHash}`);
|
|
161
|
-
console.log(`success: ${result.success}`);
|
|
162
|
-
if (result.blockNumber !== undefined) console.log(`blockNumber: ${result.blockNumber}`);
|
|
163
|
-
if (result.returnData) console.log(`returnData: ${result.returnData}`);
|
|
164
|
-
}
|
|
165
|
-
});
|
|
166
|
-
}
|