arc402-cli 1.0.0-rc.1 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/README.md +43 -2
  2. package/dist/abis.d.ts +1 -0
  3. package/dist/abis.d.ts.map +1 -1
  4. package/dist/abis.js +29 -1
  5. package/dist/abis.js.map +1 -1
  6. package/dist/commands/backup.d.ts +3 -0
  7. package/dist/commands/backup.d.ts.map +1 -0
  8. package/dist/commands/backup.js +106 -0
  9. package/dist/commands/backup.js.map +1 -0
  10. package/dist/commands/compute.d.ts +14 -0
  11. package/dist/commands/compute.d.ts.map +1 -0
  12. package/dist/commands/compute.js +466 -0
  13. package/dist/commands/compute.js.map +1 -0
  14. package/dist/commands/config.d.ts.map +1 -1
  15. package/dist/commands/config.js +11 -1
  16. package/dist/commands/config.js.map +1 -1
  17. package/dist/commands/daemon.d.ts.map +1 -1
  18. package/dist/commands/daemon.js +67 -0
  19. package/dist/commands/daemon.js.map +1 -1
  20. package/dist/commands/discover.d.ts.map +1 -1
  21. package/dist/commands/discover.js +60 -15
  22. package/dist/commands/discover.js.map +1 -1
  23. package/dist/commands/doctor.d.ts +3 -0
  24. package/dist/commands/doctor.d.ts.map +1 -0
  25. package/dist/commands/doctor.js +205 -0
  26. package/dist/commands/doctor.js.map +1 -0
  27. package/dist/commands/tunnel.d.ts +3 -0
  28. package/dist/commands/tunnel.d.ts.map +1 -0
  29. package/dist/commands/tunnel.js +281 -0
  30. package/dist/commands/tunnel.js.map +1 -0
  31. package/dist/commands/wallet.d.ts.map +1 -1
  32. package/dist/commands/wallet.js +299 -65
  33. package/dist/commands/wallet.js.map +1 -1
  34. package/dist/commands/watch.d.ts.map +1 -1
  35. package/dist/commands/watch.js +146 -9
  36. package/dist/commands/watch.js.map +1 -1
  37. package/dist/commands/workroom.d.ts.map +1 -1
  38. package/dist/commands/workroom.js +112 -6
  39. package/dist/commands/workroom.js.map +1 -1
  40. package/dist/config.d.ts +13 -0
  41. package/dist/config.d.ts.map +1 -1
  42. package/dist/config.js +41 -4
  43. package/dist/config.js.map +1 -1
  44. package/dist/daemon/compute-metering.d.ts +61 -0
  45. package/dist/daemon/compute-metering.d.ts.map +1 -0
  46. package/dist/daemon/compute-metering.js +299 -0
  47. package/dist/daemon/compute-metering.js.map +1 -0
  48. package/dist/daemon/compute-session.d.ts +100 -0
  49. package/dist/daemon/compute-session.d.ts.map +1 -0
  50. package/dist/daemon/compute-session.js +231 -0
  51. package/dist/daemon/compute-session.js.map +1 -0
  52. package/dist/daemon/config.d.ts +33 -1
  53. package/dist/daemon/config.d.ts.map +1 -1
  54. package/dist/daemon/config.js +69 -0
  55. package/dist/daemon/config.js.map +1 -1
  56. package/dist/daemon/credentials.d.ts +24 -0
  57. package/dist/daemon/credentials.d.ts.map +1 -0
  58. package/dist/daemon/credentials.js +80 -0
  59. package/dist/daemon/credentials.js.map +1 -0
  60. package/dist/daemon/delivery-client.d.ts +35 -0
  61. package/dist/daemon/delivery-client.d.ts.map +1 -0
  62. package/dist/daemon/delivery-client.js +231 -0
  63. package/dist/daemon/delivery-client.js.map +1 -0
  64. package/dist/daemon/file-delivery.d.ts +98 -0
  65. package/dist/daemon/file-delivery.d.ts.map +1 -0
  66. package/dist/daemon/file-delivery.js +461 -0
  67. package/dist/daemon/file-delivery.js.map +1 -0
  68. package/dist/daemon/index.d.ts +1 -0
  69. package/dist/daemon/index.d.ts.map +1 -1
  70. package/dist/daemon/index.js +793 -227
  71. package/dist/daemon/index.js.map +1 -1
  72. package/dist/daemon/notify.d.ts +35 -6
  73. package/dist/daemon/notify.d.ts.map +1 -1
  74. package/dist/daemon/notify.js +176 -48
  75. package/dist/daemon/notify.js.map +1 -1
  76. package/dist/daemon/worker-executor.d.ts +71 -0
  77. package/dist/daemon/worker-executor.d.ts.map +1 -0
  78. package/dist/daemon/worker-executor.js +382 -0
  79. package/dist/daemon/worker-executor.js.map +1 -0
  80. package/dist/drain-v4.js +2 -2
  81. package/dist/drain-v4.js.map +1 -1
  82. package/dist/endpoint-notify.d.ts +9 -1
  83. package/dist/endpoint-notify.d.ts.map +1 -1
  84. package/dist/endpoint-notify.js +116 -3
  85. package/dist/endpoint-notify.js.map +1 -1
  86. package/dist/index.js +81 -1
  87. package/dist/index.js.map +1 -1
  88. package/dist/program.d.ts.map +1 -1
  89. package/dist/program.js +8 -0
  90. package/dist/program.js.map +1 -1
  91. package/dist/repl.d.ts.map +1 -1
  92. package/dist/repl.js +69 -486
  93. package/dist/repl.js.map +1 -1
  94. package/dist/tui/App.d.ts +12 -0
  95. package/dist/tui/App.d.ts.map +1 -0
  96. package/dist/tui/App.js +154 -0
  97. package/dist/tui/App.js.map +1 -0
  98. package/dist/tui/Footer.d.ts +11 -0
  99. package/dist/tui/Footer.d.ts.map +1 -0
  100. package/dist/tui/Footer.js +13 -0
  101. package/dist/tui/Footer.js.map +1 -0
  102. package/dist/tui/Header.d.ts +14 -0
  103. package/dist/tui/Header.d.ts.map +1 -0
  104. package/dist/tui/Header.js +19 -0
  105. package/dist/tui/Header.js.map +1 -0
  106. package/dist/tui/InputLine.d.ts +11 -0
  107. package/dist/tui/InputLine.d.ts.map +1 -0
  108. package/dist/tui/InputLine.js +145 -0
  109. package/dist/tui/InputLine.js.map +1 -0
  110. package/dist/tui/Viewport.d.ts +14 -0
  111. package/dist/tui/Viewport.d.ts.map +1 -0
  112. package/dist/tui/Viewport.js +48 -0
  113. package/dist/tui/Viewport.js.map +1 -0
  114. package/dist/tui/WalletConnectPairing.d.ts +23 -0
  115. package/dist/tui/WalletConnectPairing.d.ts.map +1 -0
  116. package/dist/tui/WalletConnectPairing.js +61 -0
  117. package/dist/tui/WalletConnectPairing.js.map +1 -0
  118. package/dist/tui/components/Button.d.ts +7 -0
  119. package/dist/tui/components/Button.d.ts.map +1 -0
  120. package/dist/tui/components/Button.js +21 -0
  121. package/dist/tui/components/Button.js.map +1 -0
  122. package/dist/tui/components/CeremonyView.d.ts +13 -0
  123. package/dist/tui/components/CeremonyView.d.ts.map +1 -0
  124. package/dist/tui/components/CeremonyView.js +10 -0
  125. package/dist/tui/components/CeremonyView.js.map +1 -0
  126. package/dist/tui/components/CompletionDropdown.d.ts +7 -0
  127. package/dist/tui/components/CompletionDropdown.d.ts.map +1 -0
  128. package/dist/tui/components/CompletionDropdown.js +23 -0
  129. package/dist/tui/components/CompletionDropdown.js.map +1 -0
  130. package/dist/tui/components/ConfirmPrompt.d.ts +9 -0
  131. package/dist/tui/components/ConfirmPrompt.d.ts.map +1 -0
  132. package/dist/tui/components/ConfirmPrompt.js +10 -0
  133. package/dist/tui/components/ConfirmPrompt.js.map +1 -0
  134. package/dist/tui/components/CustomTextInput.d.ts +15 -0
  135. package/dist/tui/components/CustomTextInput.d.ts.map +1 -0
  136. package/dist/tui/components/CustomTextInput.js +99 -0
  137. package/dist/tui/components/CustomTextInput.js.map +1 -0
  138. package/dist/tui/components/InteractiveTable.d.ts +14 -0
  139. package/dist/tui/components/InteractiveTable.d.ts.map +1 -0
  140. package/dist/tui/components/InteractiveTable.js +61 -0
  141. package/dist/tui/components/InteractiveTable.js.map +1 -0
  142. package/dist/tui/components/StepSpinner.d.ts +11 -0
  143. package/dist/tui/components/StepSpinner.d.ts.map +1 -0
  144. package/dist/tui/components/StepSpinner.js +32 -0
  145. package/dist/tui/components/StepSpinner.js.map +1 -0
  146. package/dist/tui/components/Toast.d.ts +18 -0
  147. package/dist/tui/components/Toast.d.ts.map +1 -0
  148. package/dist/tui/components/Toast.js +29 -0
  149. package/dist/tui/components/Toast.js.map +1 -0
  150. package/dist/tui/index.d.ts +2 -0
  151. package/dist/tui/index.d.ts.map +1 -0
  152. package/dist/tui/index.js +55 -0
  153. package/dist/tui/index.js.map +1 -0
  154. package/dist/tui/useChat.d.ts +11 -0
  155. package/dist/tui/useChat.d.ts.map +1 -0
  156. package/dist/tui/useChat.js +91 -0
  157. package/dist/tui/useChat.js.map +1 -0
  158. package/dist/tui/useCommand.d.ts +12 -0
  159. package/dist/tui/useCommand.d.ts.map +1 -0
  160. package/dist/tui/useCommand.js +137 -0
  161. package/dist/tui/useCommand.js.map +1 -0
  162. package/dist/tui/useNotifications.d.ts +9 -0
  163. package/dist/tui/useNotifications.d.ts.map +1 -0
  164. package/dist/tui/useNotifications.js +17 -0
  165. package/dist/tui/useNotifications.js.map +1 -0
  166. package/dist/tui/useScroll.d.ts +17 -0
  167. package/dist/tui/useScroll.d.ts.map +1 -0
  168. package/dist/tui/useScroll.js +46 -0
  169. package/dist/tui/useScroll.js.map +1 -0
  170. package/dist/ui/format.d.ts.map +1 -1
  171. package/dist/ui/format.js +2 -0
  172. package/dist/ui/format.js.map +1 -1
  173. package/dist/ui/qr-render.d.ts +25 -0
  174. package/dist/ui/qr-render.d.ts.map +1 -0
  175. package/dist/ui/qr-render.js +90 -0
  176. package/dist/ui/qr-render.js.map +1 -0
  177. package/dist/ui/rpc-fallback.d.ts +11 -0
  178. package/dist/ui/rpc-fallback.d.ts.map +1 -0
  179. package/dist/ui/rpc-fallback.js +58 -0
  180. package/dist/ui/rpc-fallback.js.map +1 -0
  181. package/dist/walletconnect.d.ts +4 -0
  182. package/dist/walletconnect.d.ts.map +1 -1
  183. package/dist/walletconnect.js.map +1 -1
  184. package/package.json +11 -3
  185. package/scripts/authorize-machine-key.ts +0 -43
  186. package/scripts/drain-wallet.ts +0 -149
  187. package/scripts/execute-spend-only.ts +0 -81
  188. package/scripts/register-agent-userop.ts +0 -186
  189. package/src/abis.ts +0 -187
  190. package/src/bundler.ts +0 -235
  191. package/src/client.ts +0 -36
  192. package/src/coinbase-smart-wallet.ts +0 -51
  193. package/src/commands/accept.ts +0 -64
  194. package/src/commands/agent-handshake.ts +0 -72
  195. package/src/commands/agent.ts +0 -691
  196. package/src/commands/agreements.ts +0 -350
  197. package/src/commands/arbitrator.ts +0 -180
  198. package/src/commands/arena-handshake.ts +0 -257
  199. package/src/commands/arena.ts +0 -122
  200. package/src/commands/cancel.ts +0 -35
  201. package/src/commands/channel.ts +0 -218
  202. package/src/commands/coldstart.ts +0 -165
  203. package/src/commands/config.ts +0 -58
  204. package/src/commands/contract-interaction.ts +0 -166
  205. package/src/commands/daemon.ts +0 -978
  206. package/src/commands/deliver.ts +0 -148
  207. package/src/commands/discover.ts +0 -297
  208. package/src/commands/dispute.ts +0 -375
  209. package/src/commands/endpoint.ts +0 -620
  210. package/src/commands/feed.ts +0 -229
  211. package/src/commands/hire.ts +0 -245
  212. package/src/commands/migrate.ts +0 -177
  213. package/src/commands/negotiate.ts +0 -271
  214. package/src/commands/openshell.ts +0 -1055
  215. package/src/commands/owner.ts +0 -35
  216. package/src/commands/policy.ts +0 -263
  217. package/src/commands/relay.ts +0 -273
  218. package/src/commands/remediate.ts +0 -24
  219. package/src/commands/reputation.ts +0 -79
  220. package/src/commands/setup.ts +0 -343
  221. package/src/commands/trust.ts +0 -27
  222. package/src/commands/verify.ts +0 -91
  223. package/src/commands/wallet.ts +0 -3280
  224. package/src/commands/watch.ts +0 -23
  225. package/src/commands/watchtower.ts +0 -248
  226. package/src/commands/workroom.ts +0 -959
  227. package/src/config.ts +0 -174
  228. package/src/daemon/config.ts +0 -308
  229. package/src/daemon/hire-listener.ts +0 -226
  230. package/src/daemon/index.ts +0 -955
  231. package/src/daemon/job-lifecycle.ts +0 -215
  232. package/src/daemon/notify.ts +0 -157
  233. package/src/daemon/token-metering.ts +0 -183
  234. package/src/daemon/userops.ts +0 -119
  235. package/src/daemon/wallet-monitor.ts +0 -90
  236. package/src/drain-v4.ts +0 -159
  237. package/src/endpoint-config.ts +0 -83
  238. package/src/endpoint-notify.ts +0 -46
  239. package/src/index.ts +0 -26
  240. package/src/openshell-runtime.ts +0 -277
  241. package/src/program.ts +0 -83
  242. package/src/repl.ts +0 -680
  243. package/src/signing.ts +0 -28
  244. package/src/telegram-notify.ts +0 -88
  245. package/src/ui/banner.ts +0 -51
  246. package/src/ui/colors.ts +0 -30
  247. package/src/ui/format.ts +0 -77
  248. package/src/ui/spinner.ts +0 -56
  249. package/src/ui/tree.ts +0 -16
  250. package/src/utils/format.ts +0 -48
  251. package/src/utils/hash.ts +0 -5
  252. package/src/utils/time.ts +0 -15
  253. package/src/wallet-router.ts +0 -178
  254. package/src/walletconnect-session.ts +0 -27
  255. package/src/walletconnect.ts +0 -294
  256. package/test/time.test.js +0 -11
  257. 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
- }
@@ -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
- }