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