@aztec/cli 0.17.0 → 0.77.0-testnet-ignition.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.
Files changed (325) hide show
  1. package/README.md +10 -16
  2. package/dest/cmds/contracts/index.d.ts +4 -0
  3. package/dest/cmds/contracts/index.d.ts.map +1 -0
  4. package/dest/cmds/contracts/index.js +12 -0
  5. package/dest/cmds/contracts/inspect_contract.d.ts +3 -0
  6. package/dest/cmds/contracts/inspect_contract.d.ts.map +1 -0
  7. package/dest/cmds/contracts/inspect_contract.js +37 -0
  8. package/dest/cmds/{parse_parameter_struct.d.ts → contracts/parse_parameter_struct.d.ts} +1 -4
  9. package/dest/cmds/contracts/parse_parameter_struct.d.ts.map +1 -0
  10. package/dest/cmds/contracts/parse_parameter_struct.js +13 -0
  11. package/dest/cmds/devnet/bootstrap_network.d.ts +3 -0
  12. package/dest/cmds/devnet/bootstrap_network.d.ts.map +1 -0
  13. package/dest/cmds/devnet/bootstrap_network.js +196 -0
  14. package/dest/cmds/devnet/faucet.d.ts +4 -0
  15. package/dest/cmds/devnet/faucet.d.ts.map +1 -0
  16. package/dest/cmds/devnet/faucet.js +26 -0
  17. package/dest/cmds/devnet/index.d.ts +4 -0
  18. package/dest/cmds/devnet/index.d.ts.map +1 -0
  19. package/dest/cmds/devnet/index.js +14 -0
  20. package/dest/cmds/infrastructure/index.d.ts +4 -0
  21. package/dest/cmds/infrastructure/index.d.ts.map +1 -0
  22. package/dest/cmds/infrastructure/index.js +24 -0
  23. package/dest/cmds/infrastructure/sequencers.d.ts +13 -0
  24. package/dest/cmds/infrastructure/sequencers.d.ts.map +1 -0
  25. package/dest/cmds/infrastructure/sequencers.js +93 -0
  26. package/dest/cmds/infrastructure/setup_l2_contract.d.ts +3 -0
  27. package/dest/cmds/infrastructure/setup_l2_contract.d.ts.map +1 -0
  28. package/dest/cmds/infrastructure/setup_l2_contract.js +43 -0
  29. package/dest/cmds/l1/advance_epoch.d.ts +3 -0
  30. package/dest/cmds/l1/advance_epoch.d.ts.map +1 -0
  31. package/dest/cmds/l1/advance_epoch.js +10 -0
  32. package/dest/cmds/l1/assume_proven_through.d.ts +3 -0
  33. package/dest/cmds/l1/assume_proven_through.d.ts.map +1 -0
  34. package/dest/cmds/l1/assume_proven_through.js +12 -0
  35. package/dest/cmds/l1/bridge_erc20.d.ts +4 -0
  36. package/dest/cmds/l1/bridge_erc20.d.ts.map +1 -0
  37. package/dest/cmds/l1/bridge_erc20.js +31 -0
  38. package/dest/cmds/l1/create_l1_account.d.ts +3 -0
  39. package/dest/cmds/l1/create_l1_account.d.ts.map +1 -0
  40. package/dest/cmds/l1/create_l1_account.js +15 -0
  41. package/dest/cmds/l1/deploy_l1_contracts.d.ts +4 -0
  42. package/dest/cmds/l1/deploy_l1_contracts.d.ts.map +1 -0
  43. package/dest/cmds/l1/deploy_l1_contracts.js +29 -0
  44. package/dest/cmds/l1/deploy_l1_verifier.d.ts +5 -0
  45. package/dest/cmds/l1/deploy_l1_verifier.d.ts.map +1 -0
  46. package/dest/cmds/l1/deploy_l1_verifier.js +54 -0
  47. package/dest/cmds/l1/deploy_new_rollup.d.ts +4 -0
  48. package/dest/cmds/l1/deploy_new_rollup.d.ts.map +1 -0
  49. package/dest/cmds/l1/deploy_new_rollup.js +19 -0
  50. package/dest/cmds/l1/get_l1_addresses.d.ts +4 -0
  51. package/dest/cmds/l1/get_l1_addresses.d.ts.map +1 -0
  52. package/dest/cmds/l1/get_l1_addresses.js +18 -0
  53. package/dest/cmds/l1/get_l1_balance.d.ts +4 -0
  54. package/dest/cmds/l1/get_l1_balance.d.ts.map +1 -0
  55. package/dest/cmds/l1/get_l1_balance.js +33 -0
  56. package/dest/cmds/l1/governance_utils.d.ts +50 -0
  57. package/dest/cmds/l1/governance_utils.d.ts.map +1 -0
  58. package/dest/cmds/l1/governance_utils.js +85 -0
  59. package/dest/cmds/l1/index.d.ts +4 -0
  60. package/dest/cmds/l1/index.d.ts.map +1 -0
  61. package/dest/cmds/l1/index.js +208 -0
  62. package/dest/cmds/l1/prover_stats.d.ts +14 -0
  63. package/dest/cmds/l1/prover_stats.d.ts.map +1 -0
  64. package/dest/cmds/l1/prover_stats.js +145 -0
  65. package/dest/cmds/l1/update_l1_validators.d.ts +30 -0
  66. package/dest/cmds/l1/update_l1_validators.d.ts.map +1 -0
  67. package/dest/cmds/l1/update_l1_validators.js +186 -0
  68. package/dest/cmds/misc/compute_selector.d.ts +3 -0
  69. package/dest/cmds/misc/compute_selector.d.ts.map +1 -0
  70. package/dest/cmds/misc/compute_selector.js +5 -0
  71. package/dest/cmds/misc/example_contracts.d.ts +3 -0
  72. package/dest/cmds/misc/example_contracts.d.ts.map +1 -0
  73. package/dest/cmds/misc/example_contracts.js +6 -0
  74. package/dest/cmds/misc/generate_bootnode_enr.d.ts +3 -0
  75. package/dest/cmds/misc/generate_bootnode_enr.d.ts.map +1 -0
  76. package/dest/cmds/misc/generate_bootnode_enr.js +5 -0
  77. package/dest/cmds/misc/generate_p2p_private_key.d.ts +3 -0
  78. package/dest/cmds/misc/generate_p2p_private_key.d.ts.map +1 -0
  79. package/dest/cmds/misc/generate_p2p_private_key.js +7 -0
  80. package/dest/cmds/misc/generate_secret_and_hash.d.ts +3 -0
  81. package/dest/cmds/misc/generate_secret_and_hash.d.ts.map +1 -0
  82. package/dest/cmds/misc/generate_secret_and_hash.js +11 -0
  83. package/dest/cmds/misc/generate_secret_key.d.ts +5 -0
  84. package/dest/cmds/misc/generate_secret_key.d.ts.map +1 -0
  85. package/dest/cmds/misc/generate_secret_key.js +6 -0
  86. package/dest/cmds/misc/index.d.ts +4 -0
  87. package/dest/cmds/misc/index.d.ts.map +1 -0
  88. package/dest/cmds/misc/index.js +44 -0
  89. package/dest/cmds/misc/setup_contracts.d.ts +7 -0
  90. package/dest/cmds/misc/setup_contracts.d.ts.map +1 -0
  91. package/dest/cmds/misc/setup_contracts.js +27 -0
  92. package/dest/cmds/misc/update/common.d.ts.map +1 -0
  93. package/dest/cmds/misc/update/common.js +3 -0
  94. package/dest/cmds/misc/update/github.d.ts.map +1 -0
  95. package/dest/cmds/misc/update/github.js +3 -0
  96. package/dest/{update → cmds/misc/update}/noir.d.ts +2 -2
  97. package/dest/cmds/misc/update/noir.d.ts.map +1 -0
  98. package/dest/cmds/misc/update/noir.js +45 -0
  99. package/dest/{update → cmds/misc/update}/npm.d.ts +3 -3
  100. package/dest/cmds/misc/update/npm.d.ts.map +1 -0
  101. package/dest/cmds/misc/update/npm.js +127 -0
  102. package/dest/cmds/misc/update/utils.d.ts +14 -0
  103. package/dest/cmds/misc/update/utils.d.ts.map +1 -0
  104. package/dest/cmds/misc/update/utils.js +38 -0
  105. package/dest/cmds/misc/update.d.ts +3 -0
  106. package/dest/cmds/misc/update.d.ts.map +1 -0
  107. package/dest/cmds/misc/update.js +52 -0
  108. package/dest/cmds/pxe/add_contract.d.ts +5 -0
  109. package/dest/cmds/pxe/add_contract.d.ts.map +1 -0
  110. package/dest/cmds/pxe/add_contract.js +29 -0
  111. package/dest/cmds/pxe/block_number.d.ts +3 -0
  112. package/dest/cmds/pxe/block_number.d.ts.map +1 -0
  113. package/dest/cmds/pxe/block_number.js +10 -0
  114. package/dest/cmds/pxe/get_account.d.ts +4 -0
  115. package/dest/cmds/pxe/get_account.d.ts.map +1 -0
  116. package/dest/cmds/pxe/get_account.js +10 -0
  117. package/dest/cmds/pxe/get_accounts.d.ts +3 -0
  118. package/dest/cmds/pxe/get_accounts.d.ts.map +1 -0
  119. package/dest/cmds/pxe/get_accounts.js +25 -0
  120. package/dest/cmds/pxe/get_block.d.ts +3 -0
  121. package/dest/cmds/pxe/get_block.d.ts.map +1 -0
  122. package/dest/cmds/pxe/get_block.js +9 -0
  123. package/dest/cmds/pxe/get_contract_data.d.ts +4 -0
  124. package/dest/cmds/pxe/get_contract_data.d.ts.map +1 -0
  125. package/dest/cmds/pxe/get_contract_data.js +31 -0
  126. package/dest/cmds/pxe/get_current_base_fee.d.ts +3 -0
  127. package/dest/cmds/pxe/get_current_base_fee.d.ts.map +1 -0
  128. package/dest/cmds/pxe/get_current_base_fee.js +7 -0
  129. package/dest/cmds/pxe/get_l1_to_l2_message_witness.d.ts +4 -0
  130. package/dest/cmds/pxe/get_l1_to_l2_message_witness.d.ts.map +1 -0
  131. package/dest/cmds/pxe/get_l1_to_l2_message_witness.js +11 -0
  132. package/dest/cmds/pxe/get_logs.d.ts +4 -0
  133. package/dest/cmds/pxe/get_logs.d.ts.map +1 -0
  134. package/dest/cmds/pxe/get_logs.js +51 -0
  135. package/dest/cmds/pxe/get_node_info.d.ts +3 -0
  136. package/dest/cmds/pxe/get_node_info.d.ts.map +1 -0
  137. package/dest/cmds/pxe/get_node_info.js +61 -0
  138. package/dest/cmds/pxe/get_pxe_info.d.ts +3 -0
  139. package/dest/cmds/pxe/get_pxe_info.d.ts.map +1 -0
  140. package/dest/cmds/pxe/get_pxe_info.js +11 -0
  141. package/dest/cmds/pxe/index.d.ts +4 -0
  142. package/dest/cmds/pxe/index.d.ts.map +1 -0
  143. package/dest/cmds/pxe/index.js +55 -0
  144. package/dest/utils/aztec.d.ts +68 -0
  145. package/dest/utils/aztec.d.ts.map +1 -0
  146. package/dest/utils/aztec.js +173 -0
  147. package/dest/{parse_args.d.ts → utils/commands.d.ts} +50 -12
  148. package/dest/utils/commands.d.ts.map +1 -0
  149. package/dest/utils/commands.js +303 -0
  150. package/dest/{encoding.d.ts → utils/encoding.d.ts} +1 -1
  151. package/dest/utils/encoding.d.ts.map +1 -0
  152. package/dest/utils/encoding.js +103 -0
  153. package/dest/utils/github.d.ts +4 -0
  154. package/dest/utils/github.d.ts.map +1 -0
  155. package/dest/utils/github.js +3 -0
  156. package/dest/utils/index.d.ts +5 -0
  157. package/dest/utils/index.d.ts.map +1 -0
  158. package/dest/utils/index.js +4 -0
  159. package/dest/utils/inspect.d.ts +17 -0
  160. package/dest/utils/inspect.d.ts.map +1 -0
  161. package/dest/utils/inspect.js +177 -0
  162. package/package.json +68 -22
  163. package/src/cmds/contracts/index.ts +34 -0
  164. package/src/cmds/contracts/inspect_contract.ts +51 -0
  165. package/src/cmds/contracts/parse_parameter_struct.ts +27 -0
  166. package/src/cmds/devnet/bootstrap_network.ts +318 -0
  167. package/src/cmds/devnet/faucet.ts +33 -0
  168. package/src/cmds/devnet/index.ts +60 -0
  169. package/src/cmds/infrastructure/index.ts +55 -0
  170. package/src/cmds/infrastructure/sequencers.ts +103 -0
  171. package/src/cmds/infrastructure/setup_l2_contract.ts +47 -0
  172. package/src/cmds/l1/advance_epoch.ts +12 -0
  173. package/src/cmds/l1/assume_proven_through.ts +19 -0
  174. package/src/cmds/l1/bridge_erc20.ts +52 -0
  175. package/src/cmds/l1/create_l1_account.ts +17 -0
  176. package/src/cmds/l1/deploy_l1_contracts.ts +63 -0
  177. package/src/cmds/l1/deploy_l1_verifier.ts +105 -0
  178. package/src/cmds/l1/deploy_new_rollup.ts +58 -0
  179. package/src/cmds/l1/get_l1_addresses.ts +30 -0
  180. package/src/cmds/l1/get_l1_balance.ts +44 -0
  181. package/src/cmds/l1/governance_utils.ts +187 -0
  182. package/src/cmds/l1/index.ts +556 -0
  183. package/src/cmds/l1/prover_stats.ts +202 -0
  184. package/src/cmds/l1/update_l1_validators.ts +238 -0
  185. package/src/cmds/misc/compute_selector.ts +7 -0
  186. package/src/cmds/misc/example_contracts.ts +12 -0
  187. package/src/cmds/misc/generate_bootnode_enr.ts +12 -0
  188. package/src/cmds/misc/generate_p2p_private_key.ts +10 -0
  189. package/src/cmds/misc/generate_secret_and_hash.ts +15 -0
  190. package/src/cmds/misc/generate_secret_key.ts +5 -0
  191. package/src/cmds/misc/index.ts +92 -0
  192. package/src/cmds/misc/setup_contracts.ts +40 -0
  193. package/src/cmds/misc/update/common.ts +16 -0
  194. package/src/cmds/misc/update/github.ts +3 -0
  195. package/src/cmds/misc/update/noir.ts +57 -0
  196. package/src/cmds/misc/update/npm.ts +154 -0
  197. package/src/cmds/misc/update/utils.ts +50 -0
  198. package/src/cmds/misc/update.ts +78 -0
  199. package/src/cmds/pxe/add_contract.ts +41 -0
  200. package/src/cmds/pxe/block_number.ts +9 -0
  201. package/src/cmds/pxe/get_account.ts +16 -0
  202. package/src/cmds/pxe/get_accounts.ts +35 -0
  203. package/src/cmds/pxe/get_block.ts +10 -0
  204. package/src/cmds/pxe/get_contract_data.ts +51 -0
  205. package/src/cmds/pxe/get_current_base_fee.ts +9 -0
  206. package/src/cmds/pxe/get_l1_to_l2_message_witness.ts +25 -0
  207. package/src/cmds/pxe/get_logs.ts +66 -0
  208. package/src/cmds/pxe/get_node_info.ts +71 -0
  209. package/src/cmds/pxe/get_pxe_info.ts +13 -0
  210. package/src/cmds/pxe/index.ts +170 -0
  211. package/src/utils/aztec.ts +248 -0
  212. package/src/utils/commands.ts +384 -0
  213. package/src/utils/encoding.ts +117 -0
  214. package/src/utils/github.ts +3 -0
  215. package/src/utils/index.ts +4 -0
  216. package/src/utils/inspect.ts +208 -0
  217. package/dest/bin/index.d.ts +0 -3
  218. package/dest/bin/index.d.ts.map +0 -1
  219. package/dest/bin/index.js +0 -19
  220. package/dest/client.d.ts +0 -17
  221. package/dest/client.d.ts.map +0 -1
  222. package/dest/client.js +0 -60
  223. package/dest/cmds/add_contract.d.ts +0 -7
  224. package/dest/cmds/add_contract.d.ts.map +0 -1
  225. package/dest/cmds/add_contract.js +0 -15
  226. package/dest/cmds/add_note.d.ts +0 -8
  227. package/dest/cmds/add_note.d.ts.map +0 -1
  228. package/dest/cmds/add_note.js +0 -13
  229. package/dest/cmds/block_number.d.ts +0 -6
  230. package/dest/cmds/block_number.d.ts.map +0 -1
  231. package/dest/cmds/block_number.js +0 -10
  232. package/dest/cmds/call.d.ts +0 -7
  233. package/dest/cmds/call.d.ts.map +0 -1
  234. package/dest/cmds/call.js +0 -18
  235. package/dest/cmds/check_deploy.d.ts +0 -7
  236. package/dest/cmds/check_deploy.d.ts.map +0 -1
  237. package/dest/cmds/check_deploy.js +0 -16
  238. package/dest/cmds/compute_selector.d.ts +0 -6
  239. package/dest/cmds/compute_selector.d.ts.map +0 -1
  240. package/dest/cmds/compute_selector.js +0 -9
  241. package/dest/cmds/create_account.d.ts +0 -7
  242. package/dest/cmds/create_account.d.ts.map +0 -1
  243. package/dest/cmds/create_account.js +0 -31
  244. package/dest/cmds/deploy.d.ts +0 -7
  245. package/dest/cmds/deploy.d.ts.map +0 -1
  246. package/dest/cmds/deploy.js +0 -58
  247. package/dest/cmds/deploy_l1_contracts.d.ts +0 -6
  248. package/dest/cmds/deploy_l1_contracts.d.ts.map +0 -1
  249. package/dest/cmds/deploy_l1_contracts.js +0 -15
  250. package/dest/cmds/example_contracts.d.ts +0 -6
  251. package/dest/cmds/example_contracts.d.ts.map +0 -1
  252. package/dest/cmds/example_contracts.js +0 -10
  253. package/dest/cmds/generate_p2p_private_key.d.ts +0 -6
  254. package/dest/cmds/generate_p2p_private_key.d.ts.map +0 -1
  255. package/dest/cmds/generate_p2p_private_key.js +0 -11
  256. package/dest/cmds/generate_private_key.d.ts +0 -6
  257. package/dest/cmds/generate_private_key.d.ts.map +0 -1
  258. package/dest/cmds/generate_private_key.js +0 -22
  259. package/dest/cmds/get_account.d.ts +0 -7
  260. package/dest/cmds/get_account.d.ts.map +0 -1
  261. package/dest/cmds/get_account.js +0 -15
  262. package/dest/cmds/get_accounts.d.ts +0 -6
  263. package/dest/cmds/get_accounts.d.ts.map +0 -1
  264. package/dest/cmds/get_accounts.js +0 -18
  265. package/dest/cmds/get_contract_data.d.ts +0 -7
  266. package/dest/cmds/get_contract_data.d.ts.map +0 -1
  267. package/dest/cmds/get_contract_data.js +0 -28
  268. package/dest/cmds/get_logs.d.ts +0 -7
  269. package/dest/cmds/get_logs.d.ts.map +0 -1
  270. package/dest/cmds/get_logs.js +0 -54
  271. package/dest/cmds/get_node_info.d.ts +0 -6
  272. package/dest/cmds/get_node_info.d.ts.map +0 -1
  273. package/dest/cmds/get_node_info.js +0 -15
  274. package/dest/cmds/get_recipient.d.ts +0 -7
  275. package/dest/cmds/get_recipient.d.ts.map +0 -1
  276. package/dest/cmds/get_recipient.js +0 -15
  277. package/dest/cmds/get_recipients.d.ts +0 -6
  278. package/dest/cmds/get_recipients.d.ts.map +0 -1
  279. package/dest/cmds/get_recipients.js +0 -18
  280. package/dest/cmds/get_tx_receipt.d.ts +0 -7
  281. package/dest/cmds/get_tx_receipt.d.ts.map +0 -1
  282. package/dest/cmds/get_tx_receipt.js +0 -16
  283. package/dest/cmds/inspect_contract.d.ts +0 -6
  284. package/dest/cmds/inspect_contract.d.ts.map +0 -1
  285. package/dest/cmds/inspect_contract.js +0 -19
  286. package/dest/cmds/parse_parameter_struct.d.ts.map +0 -1
  287. package/dest/cmds/parse_parameter_struct.js +0 -20
  288. package/dest/cmds/register_account.d.ts +0 -7
  289. package/dest/cmds/register_account.d.ts.map +0 -1
  290. package/dest/cmds/register_account.js +0 -13
  291. package/dest/cmds/register_recipient.d.ts +0 -7
  292. package/dest/cmds/register_recipient.d.ts.map +0 -1
  293. package/dest/cmds/register_recipient.js +0 -11
  294. package/dest/cmds/send.d.ts +0 -7
  295. package/dest/cmds/send.d.ts.map +0 -1
  296. package/dest/cmds/send.js +0 -27
  297. package/dest/cmds/unbox.d.ts +0 -7
  298. package/dest/cmds/unbox.d.ts.map +0 -1
  299. package/dest/cmds/unbox.js +0 -133
  300. package/dest/encoding.d.ts.map +0 -1
  301. package/dest/encoding.js +0 -114
  302. package/dest/github.d.ts.map +0 -1
  303. package/dest/github.js +0 -4
  304. package/dest/index.d.ts +0 -10
  305. package/dest/index.d.ts.map +0 -1
  306. package/dest/index.js +0 -321
  307. package/dest/parse_args.d.ts.map +0 -1
  308. package/dest/parse_args.js +0 -233
  309. package/dest/test/mocks.d.ts +0 -3
  310. package/dest/test/mocks.d.ts.map +0 -1
  311. package/dest/test/mocks.js +0 -65
  312. package/dest/update/common.d.ts.map +0 -1
  313. package/dest/update/common.js +0 -2
  314. package/dest/update/noir.d.ts.map +0 -1
  315. package/dest/update/noir.js +0 -63
  316. package/dest/update/npm.d.ts.map +0 -1
  317. package/dest/update/npm.js +0 -125
  318. package/dest/update/update.d.ts +0 -3
  319. package/dest/update/update.d.ts.map +0 -1
  320. package/dest/update/update.js +0 -58
  321. package/dest/utils.d.ts +0 -70
  322. package/dest/utils.d.ts.map +0 -1
  323. package/dest/utils.js +0 -168
  324. /package/dest/{update → cmds/misc/update}/common.d.ts +0 -0
  325. /package/dest/{github.d.ts → cmds/misc/update/github.d.ts} +0 -0
@@ -0,0 +1,57 @@
1
+ import type { LogFn } from '@aztec/foundation/log';
2
+ import { parseNoirPackageConfig } from '@aztec/foundation/noir';
3
+
4
+ import TOML from '@iarna/toml';
5
+ import { readFile } from 'fs/promises';
6
+ import { join, relative, resolve } from 'path';
7
+
8
+ import type { DependencyChanges } from './common.js';
9
+ import { atomicUpdateFile, prettyPrintNargoToml } from './utils.js';
10
+
11
+ /**
12
+ * Updates Aztec.nr dependencies
13
+ * @param contractPath - Path to the contract to be updated
14
+ * @param tag - The tag to update to
15
+ * @param log - Logging function
16
+ */
17
+ export async function updateAztecNr(contractPath: string, tag: string, log: LogFn): Promise<DependencyChanges> {
18
+ const configFilepath = resolve(join(contractPath, 'Nargo.toml'));
19
+ const packageConfig = parseNoirPackageConfig(TOML.parse(await readFile(configFilepath, 'utf-8')));
20
+ const changes: DependencyChanges = {
21
+ dependencies: [],
22
+ file: configFilepath,
23
+ };
24
+
25
+ log(`Updating Aztec.nr libraries to ${tag} in ${relative(process.cwd(), changes.file)}`);
26
+ for (const dep of Object.values(packageConfig.dependencies)) {
27
+ if (!('git' in dep)) {
28
+ continue;
29
+ }
30
+
31
+ // remove trailing slash
32
+ const gitUrl = dep.git.toLowerCase().replace(/\/$/, '');
33
+ if (gitUrl !== 'https://github.com/aztecprotocol/aztec-packages') {
34
+ continue;
35
+ }
36
+
37
+ if (dep.tag !== tag) {
38
+ // show the Aztec.nr package name rather than the lib name
39
+ const dirParts = dep.directory?.split('/') ?? [];
40
+ changes.dependencies.push({
41
+ name: dirParts.slice(-2).join('/'),
42
+ from: dep.tag,
43
+ to: tag,
44
+ });
45
+
46
+ dep.tag = tag;
47
+ dep.directory = dep.directory?.replace('yarn-project/', 'noir-projects/');
48
+ }
49
+ }
50
+
51
+ if (changes.dependencies.length > 0) {
52
+ const contents = prettyPrintNargoToml(packageConfig);
53
+ await atomicUpdateFile(configFilepath, contents);
54
+ }
55
+
56
+ return changes;
57
+ }
@@ -0,0 +1,154 @@
1
+ import type { LogFn } from '@aztec/foundation/log';
2
+
3
+ import { spawnSync } from 'child_process';
4
+ import { existsSync } from 'fs';
5
+ import { readFile } from 'fs/promises';
6
+ import { join, relative, resolve } from 'path';
7
+ import { type SemVer, parse } from 'semver';
8
+
9
+ import type { DependencyChanges } from './common.js';
10
+ import { atomicUpdateFile } from './utils.js';
11
+
12
+ const deprecatedNpmPackages = new Set<string>(['@aztec/cli', '@aztec/aztec-sandbox']);
13
+ const npmDeprecationMessage = `
14
+ The following packages have been deprecated and will no longer be updated on the npm registry:
15
+ ${Array.from(deprecatedNpmPackages)
16
+ .map(pkg => ` - ${pkg}`)
17
+ .join('\n')}
18
+ Remove them from package.json
19
+ `;
20
+
21
+ /**
22
+ * Looks up a package.json file and returns its contents
23
+ * @param projectPath - Path to Nodejs project
24
+ * @returns The parsed package.json
25
+ */
26
+ export async function readPackageJson(projectPath: string): Promise<{
27
+ /** dependencies */
28
+ dependencies?: Record<string, string>;
29
+ /** devDependencies */
30
+ devDependencies?: Record<string, string>;
31
+ }> {
32
+ const configFilepath = resolve(join(projectPath, 'package.json'));
33
+ const pkg = JSON.parse(await readFile(configFilepath, 'utf-8'));
34
+
35
+ return pkg;
36
+ }
37
+
38
+ /**
39
+ * Queries the npm registry for the latest version of a package
40
+ * @param packageName - The package to query
41
+ * @param distTag - The distribution tag
42
+ * @returns The latest version of the package on that distribution tag
43
+ */
44
+ export async function getNewestVersion(packageName: string, distTag = 'latest'): Promise<SemVer> {
45
+ const url = new URL(packageName, 'https://registry.npmjs.org/');
46
+ const response = await fetch(url);
47
+ if (!response.ok) {
48
+ throw new Error(`Failed to fetch ${url}`);
49
+ }
50
+
51
+ const body = await response.json();
52
+ const latestVersion = parse(body['dist-tags'][distTag]);
53
+ if (!latestVersion) {
54
+ throw new Error(`Failed to get latest version from registry`);
55
+ }
56
+
57
+ return latestVersion;
58
+ }
59
+
60
+ /**
61
+ * Updates a project's \@aztec/* dependencies to the specific version
62
+ * @param projectPath - Path to Nodejs project
63
+ * @param aztecVersion - The version to update to
64
+ * @returns True if the project was updated
65
+ */
66
+ export async function updateAztecDeps(
67
+ projectPath: string,
68
+ aztecVersion: SemVer,
69
+ log: LogFn,
70
+ ): Promise<DependencyChanges> {
71
+ const pkg = await readPackageJson(projectPath);
72
+ const changes: DependencyChanges = {
73
+ file: resolve(join(projectPath, 'package.json')),
74
+ dependencies: [],
75
+ };
76
+
77
+ log(`Updating @aztec packages to ${aztecVersion} in ${relative(process.cwd(), changes.file)}`);
78
+ const version = aztecVersion.version;
79
+
80
+ let detectedDeprecatedPackages = false;
81
+
82
+ for (const depType of ['dependencies', 'devDependencies'] as const) {
83
+ const dependencies = pkg[depType];
84
+ if (!dependencies) {
85
+ continue;
86
+ }
87
+
88
+ for (const name of Object.keys(dependencies)) {
89
+ if (!name.startsWith('@aztec/')) {
90
+ continue;
91
+ }
92
+
93
+ // different release schedule
94
+ if (name === '@aztec/aztec-ui') {
95
+ continue;
96
+ }
97
+
98
+ if (deprecatedNpmPackages.has(name)) {
99
+ detectedDeprecatedPackages = true;
100
+ continue;
101
+ }
102
+
103
+ if (dependencies[name] !== version) {
104
+ changes.dependencies.push({
105
+ name,
106
+ from: dependencies[name],
107
+ to: version,
108
+ });
109
+
110
+ dependencies[name] = version;
111
+ }
112
+ }
113
+ }
114
+
115
+ if (detectedDeprecatedPackages) {
116
+ log(npmDeprecationMessage);
117
+ }
118
+
119
+ if (changes.dependencies.length > 0) {
120
+ const contents = JSON.stringify(pkg, null, 2) + '\n';
121
+ await atomicUpdateFile(resolve(join(projectPath, 'package.json')), contents);
122
+ }
123
+
124
+ return changes;
125
+ }
126
+
127
+ /**
128
+ * Updates a project's yarn.lock or package-lock.json
129
+ * @param projectPath - Path to Nodejs project
130
+ */
131
+ export function updateLockfile(projectPath: string, log: LogFn): void {
132
+ const isNpm = existsSync(resolve(join(projectPath, 'package-lock.json')));
133
+ const isYarn = existsSync(resolve(join(projectPath, 'yarn.lock')));
134
+ const isPnpm = existsSync(resolve(join(projectPath, 'pnpm-lock.yaml')));
135
+
136
+ if (isPnpm) {
137
+ spawnSync('pnpm', ['install'], {
138
+ cwd: projectPath,
139
+ stdio: 'inherit',
140
+ });
141
+ } else if (isYarn) {
142
+ spawnSync('yarn', ['install'], {
143
+ cwd: projectPath,
144
+ stdio: 'inherit',
145
+ });
146
+ } else if (isNpm) {
147
+ spawnSync('npm', ['install'], {
148
+ cwd: projectPath,
149
+ stdio: 'inherit',
150
+ });
151
+ } else {
152
+ log(`No lockfile found in ${projectPath}. Skipping lockfile update...`);
153
+ }
154
+ }
@@ -0,0 +1,50 @@
1
+ import type { NoirPackageConfig } from '@aztec/foundation/noir';
2
+
3
+ import TOML from '@iarna/toml';
4
+ import { CommanderError } from 'commander';
5
+ import { rename, writeFile } from 'fs/promises';
6
+
7
+ /**
8
+ * Updates a file in place atomically.
9
+ * @param filePath - Path to file
10
+ * @param contents - New contents to write
11
+ */
12
+ export async function atomicUpdateFile(filePath: string, contents: string) {
13
+ const tmpFilepath = filePath + '.tmp';
14
+ try {
15
+ await writeFile(tmpFilepath, contents, {
16
+ // let's crash if the tmp file already exists
17
+ flag: 'wx',
18
+ });
19
+ await rename(tmpFilepath, filePath);
20
+ } catch (e) {
21
+ if (e instanceof Error && 'code' in e && e.code === 'EEXIST') {
22
+ const commanderError = new CommanderError(
23
+ 1,
24
+ e.code,
25
+ `Temporary file already exists: ${tmpFilepath}. Delete this file and try again.`,
26
+ );
27
+ commanderError.nestedError = e.message;
28
+ throw commanderError;
29
+ } else {
30
+ throw e;
31
+ }
32
+ }
33
+ }
34
+
35
+ /**
36
+ * Pretty prints Nargo.toml contents to a string
37
+ * @param config - Nargo.toml contents
38
+ * @returns The Nargo.toml contents as a string
39
+ */
40
+ export function prettyPrintNargoToml(config: NoirPackageConfig): string {
41
+ const withoutDependencies = Object.fromEntries(Object.entries(config).filter(([key]) => key !== 'dependencies'));
42
+
43
+ const partialToml = TOML.stringify(withoutDependencies);
44
+ const dependenciesToml = Object.entries(config.dependencies).map(([name, dep]) => {
45
+ const depToml = TOML.stringify.value(dep);
46
+ return `${name} = ${depToml}`;
47
+ });
48
+
49
+ return partialToml + '\n[dependencies]\n' + dependenciesToml.join('\n') + '\n';
50
+ }
@@ -0,0 +1,78 @@
1
+ /* eslint-disable jsdoc/require-jsdoc */
2
+ import type { LogFn } from '@aztec/foundation/log';
3
+
4
+ import { relative, resolve } from 'path';
5
+ import { parse } from 'semver';
6
+
7
+ import type { DependencyChanges } from './update/common.js';
8
+ import { GITHUB_TAG_PREFIX } from './update/github.js';
9
+ import { updateAztecNr } from './update/noir.js';
10
+ import { getNewestVersion, updateAztecDeps, updateLockfile } from './update/npm.js';
11
+
12
+ const AZTECJS_PACKAGE = '@aztec/aztec.js';
13
+ const UPDATE_DOCS_URL = 'https://docs.aztec.network/developers/guides/local_env/versions-updating';
14
+
15
+ export async function updateProject(
16
+ projectPath: string,
17
+ contracts: string[],
18
+ aztecVersion: string,
19
+ log: LogFn,
20
+ ): Promise<void> {
21
+ const targetAztecVersion =
22
+ aztecVersion === 'latest' ? await getNewestVersion(AZTECJS_PACKAGE, 'latest') : parse(aztecVersion);
23
+
24
+ if (!targetAztecVersion) {
25
+ throw new Error(`Invalid aztec version ${aztecVersion}`);
26
+ }
27
+
28
+ const projectDependencyChanges: DependencyChanges[] = [];
29
+ try {
30
+ const npmChanges = await updateAztecDeps(resolve(process.cwd(), projectPath), targetAztecVersion, log);
31
+ if (npmChanges.dependencies.length > 0) {
32
+ updateLockfile(projectPath, log);
33
+ }
34
+
35
+ projectDependencyChanges.push(npmChanges);
36
+ } catch (err) {
37
+ if (err instanceof Error && 'code' in err && err.code === 'ENOENT') {
38
+ log(`No package.json found in ${projectPath}. Skipping npm update...`);
39
+ } else {
40
+ throw err;
41
+ }
42
+ }
43
+
44
+ for (const contract of contracts) {
45
+ try {
46
+ projectDependencyChanges.push(
47
+ await updateAztecNr(
48
+ resolve(process.cwd(), projectPath, contract),
49
+ `${GITHUB_TAG_PREFIX}-v${targetAztecVersion.version}`,
50
+ log,
51
+ ),
52
+ );
53
+ } catch (err) {
54
+ if (err instanceof Error && 'code' in err && err.code === 'ENOENT') {
55
+ log(`No Nargo.toml found in ${relative(process.cwd(), contract)}. Skipping...`);
56
+ } else {
57
+ throw err;
58
+ }
59
+ }
60
+ }
61
+
62
+ log(`To update Docker containers follow instructions at ${UPDATE_DOCS_URL}`);
63
+
64
+ projectDependencyChanges.forEach(changes => {
65
+ printChanges(changes, log);
66
+ });
67
+ }
68
+
69
+ function printChanges(changes: DependencyChanges, log: LogFn): void {
70
+ log(`\nIn ${relative(process.cwd(), changes.file)}:`);
71
+ if (changes.dependencies.length === 0) {
72
+ log(' No changes');
73
+ } else {
74
+ changes.dependencies.forEach(({ name, from, to }) => {
75
+ log(` Updated ${name} from ${from} to ${to}`);
76
+ });
77
+ }
78
+ }
@@ -0,0 +1,41 @@
1
+ import { AztecAddress, type ContractInstanceWithAddress, type Fr, getContractClassFromArtifact } from '@aztec/aztec.js';
2
+ import { createCompatibleClient } from '@aztec/aztec.js';
3
+ import type { LogFn, Logger } from '@aztec/foundation/log';
4
+ import { computeContractAddressFromInstance } from '@aztec/stdlib/contract';
5
+ import { PublicKeys } from '@aztec/stdlib/keys';
6
+
7
+ import { getContractArtifact } from '../../utils/aztec.js';
8
+
9
+ export async function addContract(
10
+ rpcUrl: string,
11
+ contractArtifactPath: string,
12
+ address: AztecAddress,
13
+ initializationHash: Fr,
14
+ salt: Fr,
15
+ publicKeys: PublicKeys,
16
+ deployer: AztecAddress | undefined,
17
+ debugLogger: Logger,
18
+ log: LogFn,
19
+ ) {
20
+ const artifact = await getContractArtifact(contractArtifactPath, log);
21
+ const contractClass = await getContractClassFromArtifact(artifact);
22
+ const instance: ContractInstanceWithAddress = {
23
+ version: 1,
24
+ salt,
25
+ initializationHash,
26
+ currentContractClassId: contractClass.id,
27
+ originalContractClassId: contractClass.id,
28
+ publicKeys: publicKeys ?? PublicKeys.default(),
29
+ address,
30
+ deployer: deployer ?? AztecAddress.ZERO,
31
+ };
32
+ const computed = await computeContractAddressFromInstance(instance);
33
+ if (!computed.equals(address)) {
34
+ throw new Error(`Contract address ${address.toString()} does not match computed address ${computed.toString()}`);
35
+ }
36
+
37
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
38
+
39
+ await client.registerContract({ artifact, instance });
40
+ log(`\nContract added to PXE at ${address.toString()} with class ${instance.currentContractClassId.toString()}\n`);
41
+ }
@@ -0,0 +1,9 @@
1
+ import { createCompatibleClient } from '@aztec/aztec.js';
2
+ import type { LogFn, Logger } from '@aztec/foundation/log';
3
+
4
+ export async function blockNumber(rpcUrl: string, debugLogger: Logger, log: LogFn) {
5
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
6
+ const [latestNum, provenNum] = await Promise.all([client.getBlockNumber(), client.getProvenBlockNumber()]);
7
+ log(`Latest block: ${latestNum}`);
8
+ log(`Proven block: ${provenNum}`);
9
+ }
@@ -0,0 +1,16 @@
1
+ import type { AztecAddress } from '@aztec/aztec.js';
2
+ import { createCompatibleClient } from '@aztec/aztec.js';
3
+ import type { LogFn, Logger } from '@aztec/foundation/log';
4
+
5
+ export async function getAccount(aztecAddress: AztecAddress, rpcUrl: string, debugLogger: Logger, log: LogFn) {
6
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
7
+ const account = (await client.getRegisteredAccounts()).find(completeAddress =>
8
+ completeAddress.address.equals(aztecAddress),
9
+ );
10
+
11
+ if (!account) {
12
+ log(`Unknown account ${aztecAddress.toString()}`);
13
+ } else {
14
+ log(account.toReadableString());
15
+ }
16
+ }
@@ -0,0 +1,35 @@
1
+ import { createCompatibleClient } from '@aztec/aztec.js';
2
+ import type { LogFn, Logger } from '@aztec/foundation/log';
3
+
4
+ export async function getAccounts(
5
+ rpcUrl: string,
6
+ json: boolean,
7
+ debugLogger: Logger,
8
+ log: LogFn,
9
+ logJson: (output: any) => void,
10
+ ) {
11
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
12
+ const accounts = await client.getRegisteredAccounts();
13
+ if (!accounts.length) {
14
+ if (json) {
15
+ logJson([]);
16
+ } else {
17
+ log('No accounts found.');
18
+ }
19
+ return;
20
+ }
21
+ if (json) {
22
+ logJson(
23
+ accounts.map(a => ({
24
+ address: a.address.toString(),
25
+ publicKeys: a.publicKeys.toString(),
26
+ partialAddress: a.partialAddress.toString(),
27
+ })),
28
+ );
29
+ } else {
30
+ log(`Accounts found: \n`);
31
+ for (const account of accounts) {
32
+ log(account.toReadableString());
33
+ }
34
+ }
35
+ }
@@ -0,0 +1,10 @@
1
+ import { createCompatibleClient } from '@aztec/aztec.js';
2
+ import type { LogFn, Logger } from '@aztec/foundation/log';
3
+
4
+ import { inspectBlock } from '../../utils/inspect.js';
5
+
6
+ export async function getBlock(rpcUrl: string, maybeBlockNumber: number | undefined, debugLogger: Logger, log: LogFn) {
7
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
8
+ const blockNumber = maybeBlockNumber ?? (await client.getBlockNumber());
9
+ await inspectBlock(client, blockNumber, log, { showTxs: true });
10
+ }
@@ -0,0 +1,51 @@
1
+ import type { AztecAddress } from '@aztec/aztec.js';
2
+ import { createCompatibleClient } from '@aztec/aztec.js';
3
+ import type { LogFn, Logger } from '@aztec/foundation/log';
4
+
5
+ export async function getContractData(
6
+ rpcUrl: string,
7
+ contractAddress: AztecAddress,
8
+ includeBytecode: boolean,
9
+ debugLogger: Logger,
10
+ log: LogFn,
11
+ ) {
12
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
13
+ const {
14
+ contractInstance: instance,
15
+ isContractInitialized: isInitialized,
16
+ isContractPubliclyDeployed: isPubliclyDeployed,
17
+ } = await client.getContractMetadata(contractAddress);
18
+ const contractClass =
19
+ includeBytecode &&
20
+ instance &&
21
+ (await client.getContractClassMetadata(instance?.currentContractClassId)).contractClass;
22
+
23
+ const isPrivatelyDeployed = !!instance;
24
+ const initStr = isInitialized ? 'initialized' : 'not initialized';
25
+ const addrStr = contractAddress.toString();
26
+
27
+ if (isPubliclyDeployed && isPrivatelyDeployed) {
28
+ log(`Contract is ${initStr} and publicly deployed at ${addrStr}`);
29
+ } else if (isPrivatelyDeployed) {
30
+ log(`Contract is ${initStr} and registered in the local pxe at ${addrStr} but not publicly deployed`);
31
+ } else if (isPubliclyDeployed) {
32
+ log(`Contract is ${initStr} and publicly deployed at ${addrStr} but not registered in the local pxe`);
33
+ } else if (isInitialized) {
34
+ log(`Contract is initialized but not publicly deployed nor registered in the local pxe at ${addrStr}`);
35
+ } else {
36
+ log(`No contract found at ${addrStr}`);
37
+ }
38
+
39
+ if (instance) {
40
+ log(``);
41
+ Object.entries(instance).forEach(([key, value]) => {
42
+ const capitalized = key.charAt(0).toUpperCase() + key.slice(1);
43
+ log(`${capitalized}: ${value.toString()}`);
44
+ });
45
+
46
+ if (contractClass) {
47
+ log(`\nBytecode: ${contractClass.packedBytecode.toString('base64')}`);
48
+ }
49
+ log('');
50
+ }
51
+ }
@@ -0,0 +1,9 @@
1
+ import { createCompatibleClient } from '@aztec/aztec.js';
2
+ import { jsonStringify } from '@aztec/foundation/json-rpc';
3
+ import type { LogFn, Logger } from '@aztec/foundation/log';
4
+
5
+ export async function getCurrentBaseFee(rpcUrl: string, debugLogger: Logger, log: LogFn) {
6
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
7
+ const fees = await client.getCurrentBaseFees();
8
+ log(`Current fees: ${jsonStringify(fees)}`);
9
+ }
@@ -0,0 +1,25 @@
1
+ import { type AztecAddress, type Fr, createCompatibleClient } from '@aztec/aztec.js';
2
+ import type { LogFn, Logger } from '@aztec/foundation/log';
3
+
4
+ export async function getL1ToL2MessageWitness(
5
+ rpcUrl: string,
6
+ contractAddress: AztecAddress,
7
+ messageHash: Fr,
8
+ secret: Fr,
9
+ debugLogger: Logger,
10
+ log: LogFn,
11
+ ) {
12
+ const client = await createCompatibleClient(rpcUrl, debugLogger);
13
+ const messageWitness = await client.getL1ToL2MembershipWitness(contractAddress, messageHash, secret);
14
+
15
+ log(
16
+ messageWitness === undefined
17
+ ? `
18
+ L1 to L2 Message not found.
19
+ `
20
+ : `
21
+ L1 to L2 message index: ${messageWitness[0]}
22
+ L1 to L2 message sibling path: ${messageWitness[1]}
23
+ `,
24
+ );
25
+ }
@@ -0,0 +1,66 @@
1
+ import type { AztecAddress, LogFilter, LogId, TxHash } from '@aztec/aztec.js';
2
+ import { createCompatibleClient } from '@aztec/aztec.js';
3
+ import type { LogFn, Logger } from '@aztec/foundation/log';
4
+ import { sleep } from '@aztec/foundation/sleep';
5
+
6
+ export async function getLogs(
7
+ txHash: TxHash,
8
+ fromBlock: number,
9
+ toBlock: number,
10
+ afterLog: LogId,
11
+ contractAddress: AztecAddress,
12
+ rpcUrl: string,
13
+ follow: boolean,
14
+ debugLogger: Logger,
15
+ log: LogFn,
16
+ ) {
17
+ const pxe = await createCompatibleClient(rpcUrl, debugLogger);
18
+
19
+ if (follow) {
20
+ if (txHash) {
21
+ throw Error('Cannot use --follow with --tx-hash');
22
+ }
23
+ if (toBlock) {
24
+ throw Error('Cannot use --follow with --to-block');
25
+ }
26
+ }
27
+
28
+ const filter: LogFilter = { txHash, fromBlock, toBlock, afterLog, contractAddress };
29
+
30
+ const fetchLogs = async () => {
31
+ const response = await pxe.getPublicLogs(filter);
32
+ const logs = response.logs;
33
+
34
+ if (!logs.length) {
35
+ const filterOptions = Object.entries(filter)
36
+ .filter(([, value]) => value !== undefined)
37
+ .map(([key, value]) => `${key}: ${value}`)
38
+ .join(', ');
39
+ if (!follow) {
40
+ log(`No logs found for filter: {${filterOptions}}`);
41
+ }
42
+ } else {
43
+ if (!follow && !filter.afterLog) {
44
+ log('Logs found: \n');
45
+ }
46
+ logs.forEach(publicLog => log(publicLog.toHumanReadable()));
47
+ // Set the continuation parameter for the following requests
48
+ filter.afterLog = logs[logs.length - 1].id;
49
+ }
50
+ return response.maxLogsHit;
51
+ };
52
+
53
+ if (follow) {
54
+ log('Fetching logs...');
55
+ while (true) {
56
+ const maxLogsHit = await fetchLogs();
57
+ if (!maxLogsHit) {
58
+ await sleep(1000);
59
+ }
60
+ }
61
+ } else {
62
+ while (await fetchLogs()) {
63
+ // Keep fetching logs until we reach the end.
64
+ }
65
+ }
66
+ }
@@ -0,0 +1,71 @@
1
+ import { type AztecNode, type PXE, createAztecNodeClient, createCompatibleClient } from '@aztec/aztec.js';
2
+ import type { LogFn, Logger } from '@aztec/foundation/log';
3
+
4
+ export async function getNodeInfo(
5
+ rpcUrl: string,
6
+ pxeRequest: boolean,
7
+ debugLogger: Logger,
8
+ json: boolean,
9
+ log: LogFn,
10
+ logJson: (output: any) => void,
11
+ ) {
12
+ let client: AztecNode | PXE;
13
+ if (pxeRequest) {
14
+ client = await createCompatibleClient(rpcUrl, debugLogger);
15
+ } else {
16
+ client = createAztecNodeClient(rpcUrl);
17
+ }
18
+ const info = await client.getNodeInfo();
19
+ if (json) {
20
+ logJson({
21
+ nodeVersion: info.nodeVersion,
22
+ l1ChainId: info.l1ChainId,
23
+ protocolVersion: info.protocolVersion,
24
+ enr: info.enr,
25
+ l1ContractAddresses: {
26
+ rollup: info.l1ContractAddresses.rollupAddress.toString(),
27
+ registry: info.l1ContractAddresses.registryAddress.toString(),
28
+ inbox: info.l1ContractAddresses.inboxAddress.toString(),
29
+ outbox: info.l1ContractAddresses.outboxAddress.toString(),
30
+ feeJuice: info.l1ContractAddresses.feeJuiceAddress.toString(),
31
+ stakingAsset: info.l1ContractAddresses.stakingAssetAddress.toString(),
32
+ feeJuicePortal: info.l1ContractAddresses.feeJuicePortalAddress.toString(),
33
+ coinIssuer: info.l1ContractAddresses.coinIssuerAddress.toString(),
34
+ rewardDistributor: info.l1ContractAddresses.rewardDistributorAddress.toString(),
35
+ governanceProposer: info.l1ContractAddresses.governanceProposerAddress.toString(),
36
+ governance: info.l1ContractAddresses.governanceAddress.toString(),
37
+ slashFactory: info.l1ContractAddresses.slashFactoryAddress?.toString(),
38
+ },
39
+ protocolContractAddresses: {
40
+ classRegisterer: info.protocolContractAddresses.classRegisterer.toString(),
41
+ feeJuice: info.protocolContractAddresses.feeJuice.toString(),
42
+ instanceDeployer: info.protocolContractAddresses.instanceDeployer.toString(),
43
+ multiCallEntrypoint: info.protocolContractAddresses.multiCallEntrypoint.toString(),
44
+ },
45
+ });
46
+ } else {
47
+ log(`Node Version: ${info.nodeVersion}`);
48
+ log(`Chain Id: ${info.l1ChainId}`);
49
+ log(`Protocol Version: ${info.protocolVersion}`);
50
+ log(`Node ENR: ${info.enr}`);
51
+ log(`L1 Contract Addresses:`);
52
+ log(` Rollup Address: ${info.l1ContractAddresses.rollupAddress.toString()}`);
53
+ log(` Registry Address: ${info.l1ContractAddresses.registryAddress.toString()}`);
54
+ log(` L1 -> L2 Inbox Address: ${info.l1ContractAddresses.inboxAddress.toString()}`);
55
+ log(` L2 -> L1 Outbox Address: ${info.l1ContractAddresses.outboxAddress.toString()}`);
56
+ log(` Fee Juice Address: ${info.l1ContractAddresses.feeJuiceAddress.toString()}`);
57
+ log(` Staking Asset Address: ${info.l1ContractAddresses.stakingAssetAddress.toString()}`);
58
+ log(` Fee Juice Portal Address: ${info.l1ContractAddresses.feeJuicePortalAddress.toString()}`);
59
+ log(` CoinIssuer Address: ${info.l1ContractAddresses.coinIssuerAddress.toString()}`);
60
+ log(` RewardDistributor Address: ${info.l1ContractAddresses.rewardDistributorAddress.toString()}`);
61
+ log(` GovernanceProposer Address: ${info.l1ContractAddresses.governanceProposerAddress.toString()}`);
62
+ log(` Governance Address: ${info.l1ContractAddresses.governanceAddress.toString()}`);
63
+ log(` SlashFactory Address: ${info.l1ContractAddresses.slashFactoryAddress?.toString()}`);
64
+
65
+ log(`L2 Contract Addresses:`);
66
+ log(` Class Registerer: ${info.protocolContractAddresses.classRegisterer.toString()}`);
67
+ log(` Fee Juice: ${info.protocolContractAddresses.feeJuice.toString()}`);
68
+ log(` Instance Deployer: ${info.protocolContractAddresses.instanceDeployer.toString()}`);
69
+ log(` MultiCall: ${info.protocolContractAddresses.multiCallEntrypoint.toString()}`);
70
+ }
71
+ }