chia-blockchain 2.5.1rc1__py3-none-any.whl

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 (1042) hide show
  1. chia/__init__.py +10 -0
  2. chia/__main__.py +5 -0
  3. chia/_tests/README.md +53 -0
  4. chia/_tests/__init__.py +0 -0
  5. chia/_tests/blockchain/__init__.py +0 -0
  6. chia/_tests/blockchain/blockchain_test_utils.py +195 -0
  7. chia/_tests/blockchain/config.py +4 -0
  8. chia/_tests/blockchain/test_augmented_chain.py +145 -0
  9. chia/_tests/blockchain/test_blockchain.py +4202 -0
  10. chia/_tests/blockchain/test_blockchain_transactions.py +1031 -0
  11. chia/_tests/blockchain/test_build_chains.py +59 -0
  12. chia/_tests/blockchain/test_get_block_generator.py +72 -0
  13. chia/_tests/blockchain/test_lookup_fork_chain.py +194 -0
  14. chia/_tests/build-init-files.py +92 -0
  15. chia/_tests/build-job-matrix.py +204 -0
  16. chia/_tests/check_pytest_monitor_output.py +34 -0
  17. chia/_tests/check_sql_statements.py +72 -0
  18. chia/_tests/chia-start-sim +42 -0
  19. chia/_tests/clvm/__init__.py +0 -0
  20. chia/_tests/clvm/benchmark_costs.py +23 -0
  21. chia/_tests/clvm/coin_store.py +149 -0
  22. chia/_tests/clvm/test_chialisp_deserialization.py +101 -0
  23. chia/_tests/clvm/test_clvm_step.py +37 -0
  24. chia/_tests/clvm/test_condition_codes.py +13 -0
  25. chia/_tests/clvm/test_curry_and_treehash.py +55 -0
  26. chia/_tests/clvm/test_message_conditions.py +184 -0
  27. chia/_tests/clvm/test_program.py +150 -0
  28. chia/_tests/clvm/test_puzzle_compression.py +143 -0
  29. chia/_tests/clvm/test_puzzle_drivers.py +45 -0
  30. chia/_tests/clvm/test_puzzles.py +242 -0
  31. chia/_tests/clvm/test_singletons.py +540 -0
  32. chia/_tests/clvm/test_spend_sim.py +181 -0
  33. chia/_tests/cmds/__init__.py +0 -0
  34. chia/_tests/cmds/cmd_test_utils.py +469 -0
  35. chia/_tests/cmds/config.py +3 -0
  36. chia/_tests/cmds/conftest.py +23 -0
  37. chia/_tests/cmds/test_click_types.py +200 -0
  38. chia/_tests/cmds/test_cmd_framework.py +620 -0
  39. chia/_tests/cmds/test_cmds_util.py +97 -0
  40. chia/_tests/cmds/test_daemon.py +92 -0
  41. chia/_tests/cmds/test_dev_gh.py +131 -0
  42. chia/_tests/cmds/test_farm_cmd.py +66 -0
  43. chia/_tests/cmds/test_show.py +116 -0
  44. chia/_tests/cmds/test_sim.py +207 -0
  45. chia/_tests/cmds/test_timelock_args.py +75 -0
  46. chia/_tests/cmds/test_tx_config_args.py +154 -0
  47. chia/_tests/cmds/testing_classes.py +59 -0
  48. chia/_tests/cmds/wallet/__init__.py +0 -0
  49. chia/_tests/cmds/wallet/test_consts.py +47 -0
  50. chia/_tests/cmds/wallet/test_dao.py +565 -0
  51. chia/_tests/cmds/wallet/test_did.py +403 -0
  52. chia/_tests/cmds/wallet/test_nft.py +471 -0
  53. chia/_tests/cmds/wallet/test_notifications.py +124 -0
  54. chia/_tests/cmds/wallet/test_offer.toffer +1 -0
  55. chia/_tests/cmds/wallet/test_tx_decorators.py +27 -0
  56. chia/_tests/cmds/wallet/test_vcs.py +400 -0
  57. chia/_tests/cmds/wallet/test_wallet.py +1125 -0
  58. chia/_tests/cmds/wallet/test_wallet_check.py +109 -0
  59. chia/_tests/conftest.py +1419 -0
  60. chia/_tests/connection_utils.py +125 -0
  61. chia/_tests/core/__init__.py +0 -0
  62. chia/_tests/core/cmds/__init__.py +0 -0
  63. chia/_tests/core/cmds/test_beta.py +382 -0
  64. chia/_tests/core/cmds/test_keys.py +1734 -0
  65. chia/_tests/core/cmds/test_wallet.py +126 -0
  66. chia/_tests/core/config.py +3 -0
  67. chia/_tests/core/consensus/__init__.py +0 -0
  68. chia/_tests/core/consensus/test_block_creation.py +54 -0
  69. chia/_tests/core/consensus/test_pot_iterations.py +117 -0
  70. chia/_tests/core/custom_types/__init__.py +0 -0
  71. chia/_tests/core/custom_types/test_coin.py +107 -0
  72. chia/_tests/core/custom_types/test_proof_of_space.py +144 -0
  73. chia/_tests/core/custom_types/test_spend_bundle.py +70 -0
  74. chia/_tests/core/daemon/__init__.py +0 -0
  75. chia/_tests/core/daemon/config.py +4 -0
  76. chia/_tests/core/daemon/test_daemon.py +2128 -0
  77. chia/_tests/core/daemon/test_daemon_register.py +109 -0
  78. chia/_tests/core/daemon/test_keychain_proxy.py +101 -0
  79. chia/_tests/core/data_layer/__init__.py +0 -0
  80. chia/_tests/core/data_layer/config.py +5 -0
  81. chia/_tests/core/data_layer/conftest.py +106 -0
  82. chia/_tests/core/data_layer/test_data_cli.py +56 -0
  83. chia/_tests/core/data_layer/test_data_layer.py +83 -0
  84. chia/_tests/core/data_layer/test_data_layer_util.py +218 -0
  85. chia/_tests/core/data_layer/test_data_rpc.py +3847 -0
  86. chia/_tests/core/data_layer/test_data_store.py +2424 -0
  87. chia/_tests/core/data_layer/test_data_store_schema.py +381 -0
  88. chia/_tests/core/data_layer/test_plugin.py +91 -0
  89. chia/_tests/core/data_layer/util.py +233 -0
  90. chia/_tests/core/farmer/__init__.py +0 -0
  91. chia/_tests/core/farmer/config.py +3 -0
  92. chia/_tests/core/farmer/test_farmer_api.py +103 -0
  93. chia/_tests/core/full_node/__init__.py +0 -0
  94. chia/_tests/core/full_node/config.py +4 -0
  95. chia/_tests/core/full_node/dos/__init__.py +0 -0
  96. chia/_tests/core/full_node/dos/config.py +3 -0
  97. chia/_tests/core/full_node/full_sync/__init__.py +0 -0
  98. chia/_tests/core/full_node/full_sync/config.py +4 -0
  99. chia/_tests/core/full_node/full_sync/test_full_sync.py +443 -0
  100. chia/_tests/core/full_node/ram_db.py +27 -0
  101. chia/_tests/core/full_node/stores/__init__.py +0 -0
  102. chia/_tests/core/full_node/stores/config.py +4 -0
  103. chia/_tests/core/full_node/stores/test_block_store.py +590 -0
  104. chia/_tests/core/full_node/stores/test_coin_store.py +897 -0
  105. chia/_tests/core/full_node/stores/test_full_node_store.py +1219 -0
  106. chia/_tests/core/full_node/stores/test_hint_store.py +229 -0
  107. chia/_tests/core/full_node/stores/test_sync_store.py +135 -0
  108. chia/_tests/core/full_node/test_address_manager.py +588 -0
  109. chia/_tests/core/full_node/test_block_height_map.py +556 -0
  110. chia/_tests/core/full_node/test_conditions.py +556 -0
  111. chia/_tests/core/full_node/test_full_node.py +2700 -0
  112. chia/_tests/core/full_node/test_generator_tools.py +82 -0
  113. chia/_tests/core/full_node/test_hint_management.py +104 -0
  114. chia/_tests/core/full_node/test_node_load.py +34 -0
  115. chia/_tests/core/full_node/test_performance.py +179 -0
  116. chia/_tests/core/full_node/test_subscriptions.py +492 -0
  117. chia/_tests/core/full_node/test_transactions.py +203 -0
  118. chia/_tests/core/full_node/test_tx_processing_queue.py +155 -0
  119. chia/_tests/core/large_block.py +2388 -0
  120. chia/_tests/core/make_block_generator.py +70 -0
  121. chia/_tests/core/mempool/__init__.py +0 -0
  122. chia/_tests/core/mempool/config.py +4 -0
  123. chia/_tests/core/mempool/test_mempool.py +3255 -0
  124. chia/_tests/core/mempool/test_mempool_fee_estimator.py +104 -0
  125. chia/_tests/core/mempool/test_mempool_fee_protocol.py +55 -0
  126. chia/_tests/core/mempool/test_mempool_item_queries.py +190 -0
  127. chia/_tests/core/mempool/test_mempool_manager.py +2084 -0
  128. chia/_tests/core/mempool/test_mempool_performance.py +64 -0
  129. chia/_tests/core/mempool/test_singleton_fast_forward.py +567 -0
  130. chia/_tests/core/node_height.py +28 -0
  131. chia/_tests/core/server/__init__.py +0 -0
  132. chia/_tests/core/server/config.py +3 -0
  133. chia/_tests/core/server/flood.py +84 -0
  134. chia/_tests/core/server/serve.py +135 -0
  135. chia/_tests/core/server/test_api_protocol.py +21 -0
  136. chia/_tests/core/server/test_capabilities.py +66 -0
  137. chia/_tests/core/server/test_dos.py +319 -0
  138. chia/_tests/core/server/test_event_loop.py +109 -0
  139. chia/_tests/core/server/test_loop.py +294 -0
  140. chia/_tests/core/server/test_node_discovery.py +73 -0
  141. chia/_tests/core/server/test_rate_limits.py +482 -0
  142. chia/_tests/core/server/test_server.py +226 -0
  143. chia/_tests/core/server/test_upnp.py +8 -0
  144. chia/_tests/core/services/__init__.py +0 -0
  145. chia/_tests/core/services/config.py +3 -0
  146. chia/_tests/core/services/test_services.py +188 -0
  147. chia/_tests/core/ssl/__init__.py +0 -0
  148. chia/_tests/core/ssl/config.py +3 -0
  149. chia/_tests/core/ssl/test_ssl.py +202 -0
  150. chia/_tests/core/test_coins.py +33 -0
  151. chia/_tests/core/test_cost_calculation.py +313 -0
  152. chia/_tests/core/test_crawler.py +175 -0
  153. chia/_tests/core/test_crawler_rpc.py +53 -0
  154. chia/_tests/core/test_daemon_rpc.py +24 -0
  155. chia/_tests/core/test_db_conversion.py +130 -0
  156. chia/_tests/core/test_db_validation.py +162 -0
  157. chia/_tests/core/test_farmer_harvester_rpc.py +505 -0
  158. chia/_tests/core/test_filter.py +35 -0
  159. chia/_tests/core/test_full_node_rpc.py +768 -0
  160. chia/_tests/core/test_merkle_set.py +343 -0
  161. chia/_tests/core/test_program.py +47 -0
  162. chia/_tests/core/test_rpc_util.py +86 -0
  163. chia/_tests/core/test_seeder.py +420 -0
  164. chia/_tests/core/test_setproctitle.py +13 -0
  165. chia/_tests/core/util/__init__.py +0 -0
  166. chia/_tests/core/util/config.py +4 -0
  167. chia/_tests/core/util/test_block_cache.py +44 -0
  168. chia/_tests/core/util/test_cached_bls.py +57 -0
  169. chia/_tests/core/util/test_config.py +337 -0
  170. chia/_tests/core/util/test_file_keyring_synchronization.py +105 -0
  171. chia/_tests/core/util/test_files.py +391 -0
  172. chia/_tests/core/util/test_jsonify.py +146 -0
  173. chia/_tests/core/util/test_keychain.py +522 -0
  174. chia/_tests/core/util/test_keyring_wrapper.py +491 -0
  175. chia/_tests/core/util/test_lockfile.py +380 -0
  176. chia/_tests/core/util/test_log_exceptions.py +187 -0
  177. chia/_tests/core/util/test_lru_cache.py +56 -0
  178. chia/_tests/core/util/test_significant_bits.py +40 -0
  179. chia/_tests/core/util/test_streamable.py +883 -0
  180. chia/_tests/db/__init__.py +0 -0
  181. chia/_tests/db/test_db_wrapper.py +566 -0
  182. chia/_tests/environments/__init__.py +0 -0
  183. chia/_tests/environments/common.py +35 -0
  184. chia/_tests/environments/full_node.py +47 -0
  185. chia/_tests/environments/wallet.py +429 -0
  186. chia/_tests/ether.py +19 -0
  187. chia/_tests/farmer_harvester/__init__.py +0 -0
  188. chia/_tests/farmer_harvester/config.py +3 -0
  189. chia/_tests/farmer_harvester/test_farmer.py +1264 -0
  190. chia/_tests/farmer_harvester/test_farmer_harvester.py +292 -0
  191. chia/_tests/farmer_harvester/test_filter_prefix_bits.py +131 -0
  192. chia/_tests/farmer_harvester/test_third_party_harvesters.py +528 -0
  193. chia/_tests/farmer_harvester/test_third_party_harvesters_data.json +29 -0
  194. chia/_tests/fee_estimation/__init__.py +0 -0
  195. chia/_tests/fee_estimation/config.py +3 -0
  196. chia/_tests/fee_estimation/test_fee_estimation_integration.py +262 -0
  197. chia/_tests/fee_estimation/test_fee_estimation_rpc.py +287 -0
  198. chia/_tests/fee_estimation/test_fee_estimation_unit_tests.py +144 -0
  199. chia/_tests/fee_estimation/test_mempoolitem_height_added.py +146 -0
  200. chia/_tests/generator/__init__.py +0 -0
  201. chia/_tests/generator/puzzles/__init__.py +0 -0
  202. chia/_tests/generator/puzzles/test_generator_deserialize.clsp +3 -0
  203. chia/_tests/generator/puzzles/test_generator_deserialize.clsp.hex +1 -0
  204. chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp +19 -0
  205. chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp.hex +1 -0
  206. chia/_tests/generator/test_compression.py +201 -0
  207. chia/_tests/generator/test_generator_types.py +44 -0
  208. chia/_tests/generator/test_rom.py +180 -0
  209. chia/_tests/plot_sync/__init__.py +0 -0
  210. chia/_tests/plot_sync/config.py +3 -0
  211. chia/_tests/plot_sync/test_delta.py +101 -0
  212. chia/_tests/plot_sync/test_plot_sync.py +618 -0
  213. chia/_tests/plot_sync/test_receiver.py +451 -0
  214. chia/_tests/plot_sync/test_sender.py +116 -0
  215. chia/_tests/plot_sync/test_sync_simulated.py +451 -0
  216. chia/_tests/plot_sync/util.py +68 -0
  217. chia/_tests/plotting/__init__.py +0 -0
  218. chia/_tests/plotting/config.py +3 -0
  219. chia/_tests/plotting/test_plot_manager.py +781 -0
  220. chia/_tests/plotting/util.py +12 -0
  221. chia/_tests/pools/__init__.py +0 -0
  222. chia/_tests/pools/config.py +5 -0
  223. chia/_tests/pools/test_pool_cli_parsing.py +128 -0
  224. chia/_tests/pools/test_pool_cmdline.py +1001 -0
  225. chia/_tests/pools/test_pool_config.py +42 -0
  226. chia/_tests/pools/test_pool_puzzles_lifecycle.py +397 -0
  227. chia/_tests/pools/test_pool_rpc.py +1123 -0
  228. chia/_tests/pools/test_pool_wallet.py +205 -0
  229. chia/_tests/pools/test_wallet_pool_store.py +161 -0
  230. chia/_tests/process_junit.py +348 -0
  231. chia/_tests/rpc/__init__.py +0 -0
  232. chia/_tests/rpc/test_rpc_client.py +138 -0
  233. chia/_tests/rpc/test_rpc_server.py +183 -0
  234. chia/_tests/simulation/__init__.py +0 -0
  235. chia/_tests/simulation/config.py +6 -0
  236. chia/_tests/simulation/test_simulation.py +501 -0
  237. chia/_tests/simulation/test_simulator.py +232 -0
  238. chia/_tests/simulation/test_start_simulator.py +107 -0
  239. chia/_tests/testconfig.py +13 -0
  240. chia/_tests/timelord/__init__.py +0 -0
  241. chia/_tests/timelord/config.py +3 -0
  242. chia/_tests/timelord/test_new_peak.py +437 -0
  243. chia/_tests/timelord/test_timelord.py +11 -0
  244. chia/_tests/tools/1315537.json +170 -0
  245. chia/_tests/tools/1315544.json +160 -0
  246. chia/_tests/tools/1315630.json +150 -0
  247. chia/_tests/tools/300000.json +105 -0
  248. chia/_tests/tools/442734.json +140 -0
  249. chia/_tests/tools/466212.json +130 -0
  250. chia/_tests/tools/__init__.py +0 -0
  251. chia/_tests/tools/config.py +5 -0
  252. chia/_tests/tools/test-blockchain-db.sqlite +0 -0
  253. chia/_tests/tools/test_full_sync.py +30 -0
  254. chia/_tests/tools/test_legacy_keyring.py +82 -0
  255. chia/_tests/tools/test_run_block.py +128 -0
  256. chia/_tests/tools/test_virtual_project.py +591 -0
  257. chia/_tests/util/__init__.py +0 -0
  258. chia/_tests/util/benchmark_cost.py +170 -0
  259. chia/_tests/util/benchmarks.py +153 -0
  260. chia/_tests/util/bip39_test_vectors.json +148 -0
  261. chia/_tests/util/blockchain.py +134 -0
  262. chia/_tests/util/blockchain_mock.py +132 -0
  263. chia/_tests/util/build_network_protocol_files.py +302 -0
  264. chia/_tests/util/clvm_generator.bin +0 -0
  265. chia/_tests/util/config.py +3 -0
  266. chia/_tests/util/constants.py +20 -0
  267. chia/_tests/util/db_connection.py +37 -0
  268. chia/_tests/util/full_sync.py +253 -0
  269. chia/_tests/util/gen_ssl_certs.py +114 -0
  270. chia/_tests/util/generator_tools_testing.py +45 -0
  271. chia/_tests/util/get_name_puzzle_conditions.py +52 -0
  272. chia/_tests/util/key_tool.py +36 -0
  273. chia/_tests/util/misc.py +675 -0
  274. chia/_tests/util/network_protocol_data.py +1072 -0
  275. chia/_tests/util/protocol_messages_bytes-v1.0 +0 -0
  276. chia/_tests/util/protocol_messages_json.py +2701 -0
  277. chia/_tests/util/rpc.py +26 -0
  278. chia/_tests/util/run_block.py +163 -0
  279. chia/_tests/util/setup_nodes.py +481 -0
  280. chia/_tests/util/spend_sim.py +492 -0
  281. chia/_tests/util/split_managers.py +102 -0
  282. chia/_tests/util/temp_file.py +14 -0
  283. chia/_tests/util/test_action_scope.py +144 -0
  284. chia/_tests/util/test_async_pool.py +366 -0
  285. chia/_tests/util/test_build_job_matrix.py +42 -0
  286. chia/_tests/util/test_build_network_protocol_files.py +7 -0
  287. chia/_tests/util/test_chia_version.py +50 -0
  288. chia/_tests/util/test_collection.py +11 -0
  289. chia/_tests/util/test_condition_tools.py +229 -0
  290. chia/_tests/util/test_config.py +426 -0
  291. chia/_tests/util/test_dump_keyring.py +60 -0
  292. chia/_tests/util/test_errors.py +10 -0
  293. chia/_tests/util/test_full_block_utils.py +279 -0
  294. chia/_tests/util/test_installed.py +20 -0
  295. chia/_tests/util/test_limited_semaphore.py +53 -0
  296. chia/_tests/util/test_logging_filter.py +42 -0
  297. chia/_tests/util/test_misc.py +445 -0
  298. chia/_tests/util/test_network.py +73 -0
  299. chia/_tests/util/test_network_protocol_files.py +578 -0
  300. chia/_tests/util/test_network_protocol_json.py +267 -0
  301. chia/_tests/util/test_network_protocol_test.py +256 -0
  302. chia/_tests/util/test_paginator.py +71 -0
  303. chia/_tests/util/test_pprint.py +17 -0
  304. chia/_tests/util/test_priority_mutex.py +488 -0
  305. chia/_tests/util/test_recursive_replace.py +116 -0
  306. chia/_tests/util/test_replace_str_to_bytes.py +137 -0
  307. chia/_tests/util/test_service_groups.py +15 -0
  308. chia/_tests/util/test_ssl_check.py +31 -0
  309. chia/_tests/util/test_testnet_overrides.py +19 -0
  310. chia/_tests/util/test_tests_misc.py +38 -0
  311. chia/_tests/util/test_timing.py +37 -0
  312. chia/_tests/util/test_trusted_peer.py +51 -0
  313. chia/_tests/util/time_out_assert.py +191 -0
  314. chia/_tests/wallet/__init__.py +0 -0
  315. chia/_tests/wallet/cat_wallet/__init__.py +0 -0
  316. chia/_tests/wallet/cat_wallet/config.py +4 -0
  317. chia/_tests/wallet/cat_wallet/test_cat_lifecycle.py +468 -0
  318. chia/_tests/wallet/cat_wallet/test_cat_outer_puzzle.py +69 -0
  319. chia/_tests/wallet/cat_wallet/test_cat_wallet.py +1826 -0
  320. chia/_tests/wallet/cat_wallet/test_offer_lifecycle.py +291 -0
  321. chia/_tests/wallet/cat_wallet/test_trades.py +2600 -0
  322. chia/_tests/wallet/clawback/__init__.py +0 -0
  323. chia/_tests/wallet/clawback/config.py +3 -0
  324. chia/_tests/wallet/clawback/test_clawback_decorator.py +78 -0
  325. chia/_tests/wallet/clawback/test_clawback_lifecycle.py +292 -0
  326. chia/_tests/wallet/clawback/test_clawback_metadata.py +50 -0
  327. chia/_tests/wallet/config.py +4 -0
  328. chia/_tests/wallet/conftest.py +278 -0
  329. chia/_tests/wallet/dao_wallet/__init__.py +0 -0
  330. chia/_tests/wallet/dao_wallet/config.py +3 -0
  331. chia/_tests/wallet/dao_wallet/test_dao_clvm.py +1330 -0
  332. chia/_tests/wallet/dao_wallet/test_dao_wallets.py +3488 -0
  333. chia/_tests/wallet/db_wallet/__init__.py +0 -0
  334. chia/_tests/wallet/db_wallet/config.py +3 -0
  335. chia/_tests/wallet/db_wallet/test_db_graftroot.py +141 -0
  336. chia/_tests/wallet/db_wallet/test_dl_offers.py +491 -0
  337. chia/_tests/wallet/db_wallet/test_dl_wallet.py +823 -0
  338. chia/_tests/wallet/did_wallet/__init__.py +0 -0
  339. chia/_tests/wallet/did_wallet/config.py +4 -0
  340. chia/_tests/wallet/did_wallet/test_did.py +2284 -0
  341. chia/_tests/wallet/nft_wallet/__init__.py +0 -0
  342. chia/_tests/wallet/nft_wallet/config.py +4 -0
  343. chia/_tests/wallet/nft_wallet/test_nft_1_offers.py +1493 -0
  344. chia/_tests/wallet/nft_wallet/test_nft_bulk_mint.py +1024 -0
  345. chia/_tests/wallet/nft_wallet/test_nft_lifecycle.py +375 -0
  346. chia/_tests/wallet/nft_wallet/test_nft_offers.py +1209 -0
  347. chia/_tests/wallet/nft_wallet/test_nft_puzzles.py +172 -0
  348. chia/_tests/wallet/nft_wallet/test_nft_wallet.py +2584 -0
  349. chia/_tests/wallet/nft_wallet/test_ownership_outer_puzzle.py +70 -0
  350. chia/_tests/wallet/rpc/__init__.py +0 -0
  351. chia/_tests/wallet/rpc/config.py +4 -0
  352. chia/_tests/wallet/rpc/test_dl_wallet_rpc.py +285 -0
  353. chia/_tests/wallet/rpc/test_wallet_rpc.py +3153 -0
  354. chia/_tests/wallet/simple_sync/__init__.py +0 -0
  355. chia/_tests/wallet/simple_sync/config.py +3 -0
  356. chia/_tests/wallet/simple_sync/test_simple_sync_protocol.py +718 -0
  357. chia/_tests/wallet/sync/__init__.py +0 -0
  358. chia/_tests/wallet/sync/config.py +4 -0
  359. chia/_tests/wallet/sync/test_wallet_sync.py +1692 -0
  360. chia/_tests/wallet/test_address_type.py +189 -0
  361. chia/_tests/wallet/test_bech32m.py +45 -0
  362. chia/_tests/wallet/test_clvm_streamable.py +244 -0
  363. chia/_tests/wallet/test_coin_management.py +354 -0
  364. chia/_tests/wallet/test_coin_selection.py +588 -0
  365. chia/_tests/wallet/test_conditions.py +400 -0
  366. chia/_tests/wallet/test_debug_spend_bundle.py +218 -0
  367. chia/_tests/wallet/test_new_wallet_protocol.py +1174 -0
  368. chia/_tests/wallet/test_nft_store.py +192 -0
  369. chia/_tests/wallet/test_notifications.py +196 -0
  370. chia/_tests/wallet/test_offer_parsing_performance.py +48 -0
  371. chia/_tests/wallet/test_puzzle_store.py +132 -0
  372. chia/_tests/wallet/test_sign_coin_spends.py +159 -0
  373. chia/_tests/wallet/test_signer_protocol.py +947 -0
  374. chia/_tests/wallet/test_singleton.py +122 -0
  375. chia/_tests/wallet/test_singleton_lifecycle_fast.py +772 -0
  376. chia/_tests/wallet/test_singleton_store.py +152 -0
  377. chia/_tests/wallet/test_taproot.py +19 -0
  378. chia/_tests/wallet/test_transaction_store.py +945 -0
  379. chia/_tests/wallet/test_util.py +185 -0
  380. chia/_tests/wallet/test_wallet.py +2139 -0
  381. chia/_tests/wallet/test_wallet_action_scope.py +85 -0
  382. chia/_tests/wallet/test_wallet_blockchain.py +111 -0
  383. chia/_tests/wallet/test_wallet_coin_store.py +1002 -0
  384. chia/_tests/wallet/test_wallet_interested_store.py +43 -0
  385. chia/_tests/wallet/test_wallet_key_val_store.py +40 -0
  386. chia/_tests/wallet/test_wallet_node.py +780 -0
  387. chia/_tests/wallet/test_wallet_retry.py +95 -0
  388. chia/_tests/wallet/test_wallet_state_manager.py +259 -0
  389. chia/_tests/wallet/test_wallet_test_framework.py +275 -0
  390. chia/_tests/wallet/test_wallet_trade_store.py +218 -0
  391. chia/_tests/wallet/test_wallet_user_store.py +34 -0
  392. chia/_tests/wallet/test_wallet_utils.py +156 -0
  393. chia/_tests/wallet/vc_wallet/__init__.py +0 -0
  394. chia/_tests/wallet/vc_wallet/config.py +3 -0
  395. chia/_tests/wallet/vc_wallet/test_cr_outer_puzzle.py +70 -0
  396. chia/_tests/wallet/vc_wallet/test_vc_lifecycle.py +883 -0
  397. chia/_tests/wallet/vc_wallet/test_vc_wallet.py +830 -0
  398. chia/_tests/wallet/wallet_block_tools.py +327 -0
  399. chia/_tests/weight_proof/__init__.py +0 -0
  400. chia/_tests/weight_proof/config.py +3 -0
  401. chia/_tests/weight_proof/test_weight_proof.py +528 -0
  402. chia/apis.py +19 -0
  403. chia/clvm/__init__.py +0 -0
  404. chia/cmds/__init__.py +0 -0
  405. chia/cmds/beta.py +184 -0
  406. chia/cmds/beta_funcs.py +137 -0
  407. chia/cmds/check_wallet_db.py +420 -0
  408. chia/cmds/chia.py +151 -0
  409. chia/cmds/cmd_classes.py +323 -0
  410. chia/cmds/cmd_helpers.py +242 -0
  411. chia/cmds/cmds_util.py +488 -0
  412. chia/cmds/coin_funcs.py +275 -0
  413. chia/cmds/coins.py +182 -0
  414. chia/cmds/completion.py +49 -0
  415. chia/cmds/configure.py +332 -0
  416. chia/cmds/dao.py +1064 -0
  417. chia/cmds/dao_funcs.py +598 -0
  418. chia/cmds/data.py +708 -0
  419. chia/cmds/data_funcs.py +385 -0
  420. chia/cmds/db.py +87 -0
  421. chia/cmds/db_backup_func.py +77 -0
  422. chia/cmds/db_upgrade_func.py +452 -0
  423. chia/cmds/db_validate_func.py +184 -0
  424. chia/cmds/dev.py +18 -0
  425. chia/cmds/farm.py +100 -0
  426. chia/cmds/farm_funcs.py +200 -0
  427. chia/cmds/gh.py +275 -0
  428. chia/cmds/init.py +63 -0
  429. chia/cmds/init_funcs.py +367 -0
  430. chia/cmds/installers.py +131 -0
  431. chia/cmds/keys.py +527 -0
  432. chia/cmds/keys_funcs.py +863 -0
  433. chia/cmds/netspace.py +50 -0
  434. chia/cmds/netspace_funcs.py +54 -0
  435. chia/cmds/options.py +32 -0
  436. chia/cmds/param_types.py +238 -0
  437. chia/cmds/passphrase.py +131 -0
  438. chia/cmds/passphrase_funcs.py +292 -0
  439. chia/cmds/peer.py +51 -0
  440. chia/cmds/peer_funcs.py +129 -0
  441. chia/cmds/plotnft.py +260 -0
  442. chia/cmds/plotnft_funcs.py +405 -0
  443. chia/cmds/plots.py +230 -0
  444. chia/cmds/plotters.py +18 -0
  445. chia/cmds/rpc.py +208 -0
  446. chia/cmds/show.py +72 -0
  447. chia/cmds/show_funcs.py +215 -0
  448. chia/cmds/signer.py +296 -0
  449. chia/cmds/sim.py +225 -0
  450. chia/cmds/sim_funcs.py +509 -0
  451. chia/cmds/start.py +24 -0
  452. chia/cmds/start_funcs.py +109 -0
  453. chia/cmds/stop.py +62 -0
  454. chia/cmds/units.py +9 -0
  455. chia/cmds/wallet.py +1901 -0
  456. chia/cmds/wallet_funcs.py +1874 -0
  457. chia/consensus/__init__.py +0 -0
  458. chia/consensus/block_body_validation.py +562 -0
  459. chia/consensus/block_creation.py +546 -0
  460. chia/consensus/block_header_validation.py +1059 -0
  461. chia/consensus/block_record.py +31 -0
  462. chia/consensus/block_rewards.py +53 -0
  463. chia/consensus/blockchain.py +1087 -0
  464. chia/consensus/blockchain_interface.py +56 -0
  465. chia/consensus/coinbase.py +30 -0
  466. chia/consensus/condition_costs.py +9 -0
  467. chia/consensus/constants.py +49 -0
  468. chia/consensus/cost_calculator.py +15 -0
  469. chia/consensus/default_constants.py +89 -0
  470. chia/consensus/deficit.py +55 -0
  471. chia/consensus/difficulty_adjustment.py +412 -0
  472. chia/consensus/find_fork_point.py +111 -0
  473. chia/consensus/full_block_to_block_record.py +167 -0
  474. chia/consensus/get_block_challenge.py +106 -0
  475. chia/consensus/get_block_generator.py +27 -0
  476. chia/consensus/make_sub_epoch_summary.py +210 -0
  477. chia/consensus/multiprocess_validation.py +268 -0
  478. chia/consensus/pos_quality.py +19 -0
  479. chia/consensus/pot_iterations.py +67 -0
  480. chia/consensus/puzzles/__init__.py +0 -0
  481. chia/consensus/puzzles/chialisp_deserialisation.clsp +69 -0
  482. chia/consensus/puzzles/chialisp_deserialisation.clsp.hex +1 -0
  483. chia/consensus/puzzles/rom_bootstrap_generator.clsp +37 -0
  484. chia/consensus/puzzles/rom_bootstrap_generator.clsp.hex +1 -0
  485. chia/consensus/vdf_info_computation.py +156 -0
  486. chia/daemon/__init__.py +0 -0
  487. chia/daemon/client.py +252 -0
  488. chia/daemon/keychain_proxy.py +502 -0
  489. chia/daemon/keychain_server.py +365 -0
  490. chia/daemon/server.py +1606 -0
  491. chia/daemon/windows_signal.py +56 -0
  492. chia/data_layer/__init__.py +0 -0
  493. chia/data_layer/data_layer.py +1291 -0
  494. chia/data_layer/data_layer_api.py +33 -0
  495. chia/data_layer/data_layer_errors.py +50 -0
  496. chia/data_layer/data_layer_server.py +170 -0
  497. chia/data_layer/data_layer_util.py +985 -0
  498. chia/data_layer/data_layer_wallet.py +1311 -0
  499. chia/data_layer/data_store.py +2267 -0
  500. chia/data_layer/dl_wallet_store.py +407 -0
  501. chia/data_layer/download_data.py +389 -0
  502. chia/data_layer/puzzles/__init__.py +0 -0
  503. chia/data_layer/puzzles/graftroot_dl_offers.clsp +100 -0
  504. chia/data_layer/puzzles/graftroot_dl_offers.clsp.hex +1 -0
  505. chia/data_layer/s3_plugin_config.yml +33 -0
  506. chia/data_layer/s3_plugin_service.py +468 -0
  507. chia/data_layer/util/__init__.py +0 -0
  508. chia/data_layer/util/benchmark.py +107 -0
  509. chia/data_layer/util/plugin.py +40 -0
  510. chia/farmer/__init__.py +0 -0
  511. chia/farmer/farmer.py +923 -0
  512. chia/farmer/farmer_api.py +820 -0
  513. chia/full_node/__init__.py +0 -0
  514. chia/full_node/bitcoin_fee_estimator.py +85 -0
  515. chia/full_node/block_height_map.py +271 -0
  516. chia/full_node/block_store.py +576 -0
  517. chia/full_node/bundle_tools.py +19 -0
  518. chia/full_node/coin_store.py +647 -0
  519. chia/full_node/fee_estimate.py +54 -0
  520. chia/full_node/fee_estimate_store.py +24 -0
  521. chia/full_node/fee_estimation.py +92 -0
  522. chia/full_node/fee_estimator.py +90 -0
  523. chia/full_node/fee_estimator_constants.py +38 -0
  524. chia/full_node/fee_estimator_interface.py +42 -0
  525. chia/full_node/fee_history.py +25 -0
  526. chia/full_node/fee_tracker.py +564 -0
  527. chia/full_node/full_node.py +3327 -0
  528. chia/full_node/full_node_api.py +2025 -0
  529. chia/full_node/full_node_store.py +1033 -0
  530. chia/full_node/hint_management.py +56 -0
  531. chia/full_node/hint_store.py +93 -0
  532. chia/full_node/mempool.py +589 -0
  533. chia/full_node/mempool_check_conditions.py +146 -0
  534. chia/full_node/mempool_manager.py +853 -0
  535. chia/full_node/pending_tx_cache.py +112 -0
  536. chia/full_node/puzzles/__init__.py +0 -0
  537. chia/full_node/puzzles/block_program_zero.clsp +14 -0
  538. chia/full_node/puzzles/block_program_zero.clsp.hex +1 -0
  539. chia/full_node/puzzles/decompress_coin_spend_entry.clsp +5 -0
  540. chia/full_node/puzzles/decompress_coin_spend_entry.clsp.hex +1 -0
  541. chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp +7 -0
  542. chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp.hex +1 -0
  543. chia/full_node/puzzles/decompress_puzzle.clsp +6 -0
  544. chia/full_node/puzzles/decompress_puzzle.clsp.hex +1 -0
  545. chia/full_node/signage_point.py +16 -0
  546. chia/full_node/subscriptions.py +247 -0
  547. chia/full_node/sync_store.py +146 -0
  548. chia/full_node/tx_processing_queue.py +78 -0
  549. chia/full_node/util/__init__.py +0 -0
  550. chia/full_node/weight_proof.py +1720 -0
  551. chia/harvester/__init__.py +0 -0
  552. chia/harvester/harvester.py +272 -0
  553. chia/harvester/harvester_api.py +380 -0
  554. chia/introducer/__init__.py +0 -0
  555. chia/introducer/introducer.py +122 -0
  556. chia/introducer/introducer_api.py +70 -0
  557. chia/legacy/__init__.py +0 -0
  558. chia/legacy/keyring.py +155 -0
  559. chia/plot_sync/__init__.py +0 -0
  560. chia/plot_sync/delta.py +61 -0
  561. chia/plot_sync/exceptions.py +56 -0
  562. chia/plot_sync/receiver.py +386 -0
  563. chia/plot_sync/sender.py +340 -0
  564. chia/plot_sync/util.py +43 -0
  565. chia/plotters/__init__.py +0 -0
  566. chia/plotters/bladebit.py +388 -0
  567. chia/plotters/chiapos.py +63 -0
  568. chia/plotters/madmax.py +224 -0
  569. chia/plotters/plotters.py +577 -0
  570. chia/plotters/plotters_util.py +133 -0
  571. chia/plotting/__init__.py +0 -0
  572. chia/plotting/cache.py +213 -0
  573. chia/plotting/check_plots.py +283 -0
  574. chia/plotting/create_plots.py +278 -0
  575. chia/plotting/manager.py +436 -0
  576. chia/plotting/util.py +336 -0
  577. chia/pools/__init__.py +0 -0
  578. chia/pools/pool_config.py +110 -0
  579. chia/pools/pool_puzzles.py +459 -0
  580. chia/pools/pool_wallet.py +933 -0
  581. chia/pools/pool_wallet_info.py +118 -0
  582. chia/pools/puzzles/__init__.py +0 -0
  583. chia/pools/puzzles/pool_member_innerpuz.clsp +70 -0
  584. chia/pools/puzzles/pool_member_innerpuz.clsp.hex +1 -0
  585. chia/pools/puzzles/pool_waitingroom_innerpuz.clsp +69 -0
  586. chia/pools/puzzles/pool_waitingroom_innerpuz.clsp.hex +1 -0
  587. chia/protocols/__init__.py +0 -0
  588. chia/protocols/farmer_protocol.py +102 -0
  589. chia/protocols/full_node_protocol.py +219 -0
  590. chia/protocols/harvester_protocol.py +216 -0
  591. chia/protocols/introducer_protocol.py +25 -0
  592. chia/protocols/pool_protocol.py +177 -0
  593. chia/protocols/protocol_message_types.py +139 -0
  594. chia/protocols/protocol_state_machine.py +87 -0
  595. chia/protocols/protocol_timing.py +8 -0
  596. chia/protocols/shared_protocol.py +86 -0
  597. chia/protocols/timelord_protocol.py +93 -0
  598. chia/protocols/wallet_protocol.py +401 -0
  599. chia/py.typed +0 -0
  600. chia/rpc/__init__.py +0 -0
  601. chia/rpc/crawler_rpc_api.py +80 -0
  602. chia/rpc/data_layer_rpc_api.py +644 -0
  603. chia/rpc/data_layer_rpc_client.py +188 -0
  604. chia/rpc/data_layer_rpc_util.py +58 -0
  605. chia/rpc/farmer_rpc_api.py +365 -0
  606. chia/rpc/farmer_rpc_client.py +86 -0
  607. chia/rpc/full_node_rpc_api.py +959 -0
  608. chia/rpc/full_node_rpc_client.py +292 -0
  609. chia/rpc/harvester_rpc_api.py +141 -0
  610. chia/rpc/harvester_rpc_client.py +54 -0
  611. chia/rpc/rpc_client.py +164 -0
  612. chia/rpc/rpc_server.py +521 -0
  613. chia/rpc/timelord_rpc_api.py +32 -0
  614. chia/rpc/util.py +93 -0
  615. chia/rpc/wallet_request_types.py +904 -0
  616. chia/rpc/wallet_rpc_api.py +4943 -0
  617. chia/rpc/wallet_rpc_client.py +1814 -0
  618. chia/seeder/__init__.py +0 -0
  619. chia/seeder/crawl_store.py +425 -0
  620. chia/seeder/crawler.py +410 -0
  621. chia/seeder/crawler_api.py +135 -0
  622. chia/seeder/dns_server.py +593 -0
  623. chia/seeder/peer_record.py +146 -0
  624. chia/seeder/start_crawler.py +92 -0
  625. chia/server/__init__.py +0 -0
  626. chia/server/address_manager.py +658 -0
  627. chia/server/address_manager_store.py +237 -0
  628. chia/server/api_protocol.py +116 -0
  629. chia/server/capabilities.py +24 -0
  630. chia/server/chia_policy.py +346 -0
  631. chia/server/introducer_peers.py +76 -0
  632. chia/server/node_discovery.py +714 -0
  633. chia/server/outbound_message.py +33 -0
  634. chia/server/rate_limit_numbers.py +214 -0
  635. chia/server/rate_limits.py +153 -0
  636. chia/server/server.py +741 -0
  637. chia/server/signal_handlers.py +120 -0
  638. chia/server/ssl_context.py +32 -0
  639. chia/server/start_data_layer.py +151 -0
  640. chia/server/start_farmer.py +98 -0
  641. chia/server/start_full_node.py +112 -0
  642. chia/server/start_harvester.py +93 -0
  643. chia/server/start_introducer.py +81 -0
  644. chia/server/start_service.py +316 -0
  645. chia/server/start_timelord.py +89 -0
  646. chia/server/start_wallet.py +113 -0
  647. chia/server/upnp.py +118 -0
  648. chia/server/ws_connection.py +766 -0
  649. chia/simulator/__init__.py +0 -0
  650. chia/simulator/add_blocks_in_batches.py +54 -0
  651. chia/simulator/block_tools.py +2054 -0
  652. chia/simulator/full_node_simulator.py +794 -0
  653. chia/simulator/keyring.py +128 -0
  654. chia/simulator/setup_services.py +506 -0
  655. chia/simulator/simulator_constants.py +13 -0
  656. chia/simulator/simulator_full_node_rpc_api.py +99 -0
  657. chia/simulator/simulator_full_node_rpc_client.py +60 -0
  658. chia/simulator/simulator_protocol.py +29 -0
  659. chia/simulator/simulator_test_tools.py +164 -0
  660. chia/simulator/socket.py +24 -0
  661. chia/simulator/ssl_certs.py +114 -0
  662. chia/simulator/ssl_certs_1.py +697 -0
  663. chia/simulator/ssl_certs_10.py +697 -0
  664. chia/simulator/ssl_certs_2.py +697 -0
  665. chia/simulator/ssl_certs_3.py +697 -0
  666. chia/simulator/ssl_certs_4.py +697 -0
  667. chia/simulator/ssl_certs_5.py +697 -0
  668. chia/simulator/ssl_certs_6.py +697 -0
  669. chia/simulator/ssl_certs_7.py +697 -0
  670. chia/simulator/ssl_certs_8.py +697 -0
  671. chia/simulator/ssl_certs_9.py +697 -0
  672. chia/simulator/start_simulator.py +143 -0
  673. chia/simulator/wallet_tools.py +246 -0
  674. chia/ssl/__init__.py +0 -0
  675. chia/ssl/chia_ca.crt +19 -0
  676. chia/ssl/chia_ca.key +28 -0
  677. chia/ssl/create_ssl.py +249 -0
  678. chia/ssl/dst_root_ca.pem +20 -0
  679. chia/timelord/__init__.py +0 -0
  680. chia/timelord/iters_from_block.py +50 -0
  681. chia/timelord/timelord.py +1226 -0
  682. chia/timelord/timelord_api.py +138 -0
  683. chia/timelord/timelord_launcher.py +190 -0
  684. chia/timelord/timelord_state.py +244 -0
  685. chia/timelord/types.py +22 -0
  686. chia/types/__init__.py +0 -0
  687. chia/types/aliases.py +35 -0
  688. chia/types/block_protocol.py +20 -0
  689. chia/types/blockchain_format/__init__.py +0 -0
  690. chia/types/blockchain_format/classgroup.py +5 -0
  691. chia/types/blockchain_format/coin.py +28 -0
  692. chia/types/blockchain_format/foliage.py +8 -0
  693. chia/types/blockchain_format/pool_target.py +5 -0
  694. chia/types/blockchain_format/program.py +269 -0
  695. chia/types/blockchain_format/proof_of_space.py +135 -0
  696. chia/types/blockchain_format/reward_chain_block.py +6 -0
  697. chia/types/blockchain_format/serialized_program.py +5 -0
  698. chia/types/blockchain_format/sized_bytes.py +11 -0
  699. chia/types/blockchain_format/slots.py +9 -0
  700. chia/types/blockchain_format/sub_epoch_summary.py +5 -0
  701. chia/types/blockchain_format/tree_hash.py +72 -0
  702. chia/types/blockchain_format/vdf.py +86 -0
  703. chia/types/clvm_cost.py +13 -0
  704. chia/types/coin_record.py +43 -0
  705. chia/types/coin_spend.py +115 -0
  706. chia/types/condition_opcodes.py +73 -0
  707. chia/types/condition_with_args.py +16 -0
  708. chia/types/eligible_coin_spends.py +365 -0
  709. chia/types/end_of_slot_bundle.py +5 -0
  710. chia/types/fee_rate.py +38 -0
  711. chia/types/full_block.py +5 -0
  712. chia/types/generator_types.py +13 -0
  713. chia/types/header_block.py +5 -0
  714. chia/types/internal_mempool_item.py +18 -0
  715. chia/types/mempool_inclusion_status.py +9 -0
  716. chia/types/mempool_item.py +85 -0
  717. chia/types/mempool_submission_status.py +30 -0
  718. chia/types/mojos.py +7 -0
  719. chia/types/peer_info.py +64 -0
  720. chia/types/signing_mode.py +29 -0
  721. chia/types/spend_bundle.py +30 -0
  722. chia/types/spend_bundle_conditions.py +7 -0
  723. chia/types/transaction_queue_entry.py +55 -0
  724. chia/types/unfinished_block.py +5 -0
  725. chia/types/unfinished_header_block.py +37 -0
  726. chia/types/validation_state.py +14 -0
  727. chia/types/weight_proof.py +49 -0
  728. chia/util/__init__.py +0 -0
  729. chia/util/action_scope.py +168 -0
  730. chia/util/async_pool.py +226 -0
  731. chia/util/augmented_chain.py +134 -0
  732. chia/util/batches.py +42 -0
  733. chia/util/bech32m.py +126 -0
  734. chia/util/beta_metrics.py +119 -0
  735. chia/util/block_cache.py +56 -0
  736. chia/util/byte_types.py +12 -0
  737. chia/util/check_fork_next_block.py +33 -0
  738. chia/util/chia_logging.py +144 -0
  739. chia/util/chia_version.py +33 -0
  740. chia/util/collection.py +17 -0
  741. chia/util/condition_tools.py +201 -0
  742. chia/util/config.py +367 -0
  743. chia/util/cpu.py +22 -0
  744. chia/util/db_synchronous.py +23 -0
  745. chia/util/db_version.py +32 -0
  746. chia/util/db_wrapper.py +430 -0
  747. chia/util/default_root.py +27 -0
  748. chia/util/dump_keyring.py +93 -0
  749. chia/util/english.txt +2048 -0
  750. chia/util/errors.py +353 -0
  751. chia/util/file_keyring.py +469 -0
  752. chia/util/files.py +97 -0
  753. chia/util/full_block_utils.py +345 -0
  754. chia/util/generator_tools.py +72 -0
  755. chia/util/hash.py +31 -0
  756. chia/util/initial-config.yaml +694 -0
  757. chia/util/inline_executor.py +26 -0
  758. chia/util/ints.py +19 -0
  759. chia/util/ip_address.py +39 -0
  760. chia/util/json_util.py +37 -0
  761. chia/util/keychain.py +676 -0
  762. chia/util/keyring_wrapper.py +327 -0
  763. chia/util/limited_semaphore.py +41 -0
  764. chia/util/lock.py +49 -0
  765. chia/util/log_exceptions.py +32 -0
  766. chia/util/logging.py +36 -0
  767. chia/util/lru_cache.py +31 -0
  768. chia/util/math.py +20 -0
  769. chia/util/network.py +182 -0
  770. chia/util/paginator.py +48 -0
  771. chia/util/path.py +31 -0
  772. chia/util/permissions.py +20 -0
  773. chia/util/prev_transaction_block.py +21 -0
  774. chia/util/priority_mutex.py +95 -0
  775. chia/util/profiler.py +197 -0
  776. chia/util/recursive_replace.py +24 -0
  777. chia/util/safe_cancel_task.py +16 -0
  778. chia/util/service_groups.py +47 -0
  779. chia/util/setproctitle.py +22 -0
  780. chia/util/significant_bits.py +32 -0
  781. chia/util/ssl_check.py +213 -0
  782. chia/util/streamable.py +642 -0
  783. chia/util/task_referencer.py +59 -0
  784. chia/util/task_timing.py +382 -0
  785. chia/util/timing.py +67 -0
  786. chia/util/vdf_prover.py +30 -0
  787. chia/util/virtual_project_analysis.py +540 -0
  788. chia/util/ws_message.py +66 -0
  789. chia/wallet/__init__.py +0 -0
  790. chia/wallet/cat_wallet/__init__.py +0 -0
  791. chia/wallet/cat_wallet/cat_constants.py +75 -0
  792. chia/wallet/cat_wallet/cat_info.py +47 -0
  793. chia/wallet/cat_wallet/cat_outer_puzzle.py +120 -0
  794. chia/wallet/cat_wallet/cat_utils.py +164 -0
  795. chia/wallet/cat_wallet/cat_wallet.py +855 -0
  796. chia/wallet/cat_wallet/dao_cat_info.py +28 -0
  797. chia/wallet/cat_wallet/dao_cat_wallet.py +669 -0
  798. chia/wallet/cat_wallet/lineage_store.py +74 -0
  799. chia/wallet/cat_wallet/puzzles/__init__.py +0 -0
  800. chia/wallet/cat_wallet/puzzles/cat_truths.clib +31 -0
  801. chia/wallet/cat_wallet/puzzles/cat_v2.clsp +397 -0
  802. chia/wallet/cat_wallet/puzzles/cat_v2.clsp.hex +1 -0
  803. chia/wallet/cat_wallet/puzzles/delegated_tail.clsp +25 -0
  804. chia/wallet/cat_wallet/puzzles/delegated_tail.clsp.hex +1 -0
  805. chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp +15 -0
  806. chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp.hex +1 -0
  807. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp +26 -0
  808. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp.hex +1 -0
  809. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp +42 -0
  810. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp.hex +1 -0
  811. chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp +24 -0
  812. chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp.hex +1 -0
  813. chia/wallet/coin_selection.py +188 -0
  814. chia/wallet/conditions.py +1512 -0
  815. chia/wallet/dao_wallet/__init__.py +0 -0
  816. chia/wallet/dao_wallet/dao_info.py +61 -0
  817. chia/wallet/dao_wallet/dao_utils.py +811 -0
  818. chia/wallet/dao_wallet/dao_wallet.py +2119 -0
  819. chia/wallet/db_wallet/__init__.py +0 -0
  820. chia/wallet/db_wallet/db_wallet_puzzles.py +111 -0
  821. chia/wallet/derivation_record.py +30 -0
  822. chia/wallet/derive_keys.py +146 -0
  823. chia/wallet/did_wallet/__init__.py +0 -0
  824. chia/wallet/did_wallet/did_info.py +39 -0
  825. chia/wallet/did_wallet/did_wallet.py +1494 -0
  826. chia/wallet/did_wallet/did_wallet_puzzles.py +221 -0
  827. chia/wallet/did_wallet/puzzles/__init__.py +0 -0
  828. chia/wallet/did_wallet/puzzles/did_innerpuz.clsp +135 -0
  829. chia/wallet/did_wallet/puzzles/did_innerpuz.clsp.hex +1 -0
  830. chia/wallet/driver_protocol.py +26 -0
  831. chia/wallet/key_val_store.py +55 -0
  832. chia/wallet/lineage_proof.py +58 -0
  833. chia/wallet/nft_wallet/__init__.py +0 -0
  834. chia/wallet/nft_wallet/metadata_outer_puzzle.py +92 -0
  835. chia/wallet/nft_wallet/nft_info.py +120 -0
  836. chia/wallet/nft_wallet/nft_puzzles.py +305 -0
  837. chia/wallet/nft_wallet/nft_wallet.py +1687 -0
  838. chia/wallet/nft_wallet/ownership_outer_puzzle.py +101 -0
  839. chia/wallet/nft_wallet/puzzles/__init__.py +0 -0
  840. chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp +6 -0
  841. chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp.hex +1 -0
  842. chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp +6 -0
  843. chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp.hex +1 -0
  844. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp +30 -0
  845. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp.hex +1 -0
  846. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp +28 -0
  847. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp.hex +1 -0
  848. chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp +100 -0
  849. chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp.hex +1 -0
  850. chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp +78 -0
  851. chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp.hex +1 -0
  852. chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp +74 -0
  853. chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp.hex +1 -0
  854. chia/wallet/nft_wallet/singleton_outer_puzzle.py +101 -0
  855. chia/wallet/nft_wallet/transfer_program_puzzle.py +82 -0
  856. chia/wallet/nft_wallet/uncurry_nft.py +217 -0
  857. chia/wallet/notification_manager.py +117 -0
  858. chia/wallet/notification_store.py +178 -0
  859. chia/wallet/outer_puzzles.py +84 -0
  860. chia/wallet/payment.py +33 -0
  861. chia/wallet/puzzle_drivers.py +118 -0
  862. chia/wallet/puzzles/__init__.py +0 -0
  863. chia/wallet/puzzles/augmented_condition.clsp +13 -0
  864. chia/wallet/puzzles/augmented_condition.clsp.hex +1 -0
  865. chia/wallet/puzzles/clawback/__init__.py +0 -0
  866. chia/wallet/puzzles/clawback/drivers.py +188 -0
  867. chia/wallet/puzzles/clawback/metadata.py +38 -0
  868. chia/wallet/puzzles/clawback/puzzle_decorator.py +67 -0
  869. chia/wallet/puzzles/condition_codes.clib +77 -0
  870. chia/wallet/puzzles/curry-and-treehash.clib +102 -0
  871. chia/wallet/puzzles/curry.clib +135 -0
  872. chia/wallet/puzzles/curry_by_index.clib +16 -0
  873. chia/wallet/puzzles/dao_cat_eve.clsp +17 -0
  874. chia/wallet/puzzles/dao_cat_eve.clsp.hex +1 -0
  875. chia/wallet/puzzles/dao_cat_launcher.clsp +36 -0
  876. chia/wallet/puzzles/dao_cat_launcher.clsp.hex +1 -0
  877. chia/wallet/puzzles/dao_finished_state.clsp +35 -0
  878. chia/wallet/puzzles/dao_finished_state.clsp.hex +1 -0
  879. chia/wallet/puzzles/dao_finished_state.clsp.hex.sha256tree +1 -0
  880. chia/wallet/puzzles/dao_lockup.clsp +288 -0
  881. chia/wallet/puzzles/dao_lockup.clsp.hex +1 -0
  882. chia/wallet/puzzles/dao_lockup.clsp.hex.sha256tree +1 -0
  883. chia/wallet/puzzles/dao_proposal.clsp +377 -0
  884. chia/wallet/puzzles/dao_proposal.clsp.hex +1 -0
  885. chia/wallet/puzzles/dao_proposal.clsp.hex.sha256tree +1 -0
  886. chia/wallet/puzzles/dao_proposal_timer.clsp +78 -0
  887. chia/wallet/puzzles/dao_proposal_timer.clsp.hex +1 -0
  888. chia/wallet/puzzles/dao_proposal_timer.clsp.hex.sha256tree +1 -0
  889. chia/wallet/puzzles/dao_proposal_validator.clsp +87 -0
  890. chia/wallet/puzzles/dao_proposal_validator.clsp.hex +1 -0
  891. chia/wallet/puzzles/dao_proposal_validator.clsp.hex.sha256tree +1 -0
  892. chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp +240 -0
  893. chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex +1 -0
  894. chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex.sha256tree +1 -0
  895. chia/wallet/puzzles/dao_treasury.clsp +115 -0
  896. chia/wallet/puzzles/dao_treasury.clsp.hex +1 -0
  897. chia/wallet/puzzles/dao_update_proposal.clsp +44 -0
  898. chia/wallet/puzzles/dao_update_proposal.clsp.hex +1 -0
  899. chia/wallet/puzzles/deployed_puzzle_hashes.json +67 -0
  900. chia/wallet/puzzles/json.clib +25 -0
  901. chia/wallet/puzzles/load_clvm.py +161 -0
  902. chia/wallet/puzzles/merkle_utils.clib +18 -0
  903. chia/wallet/puzzles/notification.clsp +7 -0
  904. chia/wallet/puzzles/notification.clsp.hex +1 -0
  905. chia/wallet/puzzles/p2_1_of_n.clsp +22 -0
  906. chia/wallet/puzzles/p2_1_of_n.clsp.hex +1 -0
  907. chia/wallet/puzzles/p2_conditions.clsp +3 -0
  908. chia/wallet/puzzles/p2_conditions.clsp.hex +1 -0
  909. chia/wallet/puzzles/p2_conditions.py +26 -0
  910. chia/wallet/puzzles/p2_delegated_conditions.clsp +18 -0
  911. chia/wallet/puzzles/p2_delegated_conditions.clsp.hex +1 -0
  912. chia/wallet/puzzles/p2_delegated_conditions.py +21 -0
  913. chia/wallet/puzzles/p2_delegated_puzzle.clsp +19 -0
  914. chia/wallet/puzzles/p2_delegated_puzzle.clsp.hex +1 -0
  915. chia/wallet/puzzles/p2_delegated_puzzle.py +34 -0
  916. chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp +91 -0
  917. chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp.hex +1 -0
  918. chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.py +160 -0
  919. chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp +108 -0
  920. chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp.hex +1 -0
  921. chia/wallet/puzzles/p2_m_of_n_delegate_direct.py +21 -0
  922. chia/wallet/puzzles/p2_parent.clsp +19 -0
  923. chia/wallet/puzzles/p2_parent.clsp.hex +1 -0
  924. chia/wallet/puzzles/p2_puzzle_hash.clsp +18 -0
  925. chia/wallet/puzzles/p2_puzzle_hash.clsp.hex +1 -0
  926. chia/wallet/puzzles/p2_puzzle_hash.py +27 -0
  927. chia/wallet/puzzles/p2_singleton.clsp +30 -0
  928. chia/wallet/puzzles/p2_singleton.clsp.hex +1 -0
  929. chia/wallet/puzzles/p2_singleton_aggregator.clsp +81 -0
  930. chia/wallet/puzzles/p2_singleton_aggregator.clsp.hex +1 -0
  931. chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp +50 -0
  932. chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp.hex +1 -0
  933. chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp +47 -0
  934. chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp.hex +1 -0
  935. chia/wallet/puzzles/puzzle_utils.py +34 -0
  936. chia/wallet/puzzles/settlement_payments.clsp +49 -0
  937. chia/wallet/puzzles/settlement_payments.clsp.hex +1 -0
  938. chia/wallet/puzzles/sha256tree.clib +11 -0
  939. chia/wallet/puzzles/singleton_launcher.clsp +16 -0
  940. chia/wallet/puzzles/singleton_launcher.clsp.hex +1 -0
  941. chia/wallet/puzzles/singleton_top_layer.clsp +177 -0
  942. chia/wallet/puzzles/singleton_top_layer.clsp.hex +1 -0
  943. chia/wallet/puzzles/singleton_top_layer.py +296 -0
  944. chia/wallet/puzzles/singleton_top_layer_v1_1.clsp +107 -0
  945. chia/wallet/puzzles/singleton_top_layer_v1_1.clsp.hex +1 -0
  946. chia/wallet/puzzles/singleton_top_layer_v1_1.py +345 -0
  947. chia/wallet/puzzles/singleton_truths.clib +21 -0
  948. chia/wallet/puzzles/tails.py +348 -0
  949. chia/wallet/puzzles/utility_macros.clib +48 -0
  950. chia/wallet/signer_protocol.py +125 -0
  951. chia/wallet/singleton.py +106 -0
  952. chia/wallet/singleton_record.py +30 -0
  953. chia/wallet/trade_manager.py +1102 -0
  954. chia/wallet/trade_record.py +67 -0
  955. chia/wallet/trading/__init__.py +0 -0
  956. chia/wallet/trading/offer.py +702 -0
  957. chia/wallet/trading/trade_status.py +13 -0
  958. chia/wallet/trading/trade_store.py +526 -0
  959. chia/wallet/transaction_record.py +158 -0
  960. chia/wallet/transaction_sorting.py +14 -0
  961. chia/wallet/uncurried_puzzle.py +17 -0
  962. chia/wallet/util/__init__.py +0 -0
  963. chia/wallet/util/address_type.py +55 -0
  964. chia/wallet/util/blind_signer_tl.py +164 -0
  965. chia/wallet/util/clvm_streamable.py +203 -0
  966. chia/wallet/util/compute_hints.py +66 -0
  967. chia/wallet/util/compute_memos.py +43 -0
  968. chia/wallet/util/curry_and_treehash.py +91 -0
  969. chia/wallet/util/debug_spend_bundle.py +232 -0
  970. chia/wallet/util/merkle_tree.py +100 -0
  971. chia/wallet/util/merkle_utils.py +102 -0
  972. chia/wallet/util/new_peak_queue.py +82 -0
  973. chia/wallet/util/notifications.py +12 -0
  974. chia/wallet/util/peer_request_cache.py +174 -0
  975. chia/wallet/util/pprint.py +39 -0
  976. chia/wallet/util/puzzle_compression.py +95 -0
  977. chia/wallet/util/puzzle_decorator.py +100 -0
  978. chia/wallet/util/puzzle_decorator_type.py +7 -0
  979. chia/wallet/util/query_filter.py +59 -0
  980. chia/wallet/util/transaction_type.py +23 -0
  981. chia/wallet/util/tx_config.py +158 -0
  982. chia/wallet/util/wallet_sync_utils.py +351 -0
  983. chia/wallet/util/wallet_types.py +72 -0
  984. chia/wallet/vc_wallet/__init__.py +0 -0
  985. chia/wallet/vc_wallet/cr_cat_drivers.py +664 -0
  986. chia/wallet/vc_wallet/cr_cat_wallet.py +877 -0
  987. chia/wallet/vc_wallet/cr_outer_puzzle.py +102 -0
  988. chia/wallet/vc_wallet/cr_puzzles/__init__.py +0 -0
  989. chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp +3 -0
  990. chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp.hex +1 -0
  991. chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp +304 -0
  992. chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp.hex +1 -0
  993. chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp +45 -0
  994. chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp.hex +1 -0
  995. chia/wallet/vc_wallet/vc_drivers.py +838 -0
  996. chia/wallet/vc_wallet/vc_puzzles/__init__.py +0 -0
  997. chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp +30 -0
  998. chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp.hex +1 -0
  999. chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp +75 -0
  1000. chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp.hex +1 -0
  1001. chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp +32 -0
  1002. chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp.hex +1 -0
  1003. chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp +80 -0
  1004. chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp.hex +1 -0
  1005. chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp +163 -0
  1006. chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp.hex +1 -0
  1007. chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp +16 -0
  1008. chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp.hex +1 -0
  1009. chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp +74 -0
  1010. chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp.hex +1 -0
  1011. chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp +23 -0
  1012. chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp.hex +1 -0
  1013. chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp +64 -0
  1014. chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp.hex +1 -0
  1015. chia/wallet/vc_wallet/vc_store.py +263 -0
  1016. chia/wallet/vc_wallet/vc_wallet.py +638 -0
  1017. chia/wallet/wallet.py +698 -0
  1018. chia/wallet/wallet_action_scope.py +96 -0
  1019. chia/wallet/wallet_blockchain.py +244 -0
  1020. chia/wallet/wallet_coin_record.py +72 -0
  1021. chia/wallet/wallet_coin_store.py +351 -0
  1022. chia/wallet/wallet_info.py +35 -0
  1023. chia/wallet/wallet_interested_store.py +188 -0
  1024. chia/wallet/wallet_nft_store.py +279 -0
  1025. chia/wallet/wallet_node.py +1765 -0
  1026. chia/wallet/wallet_node_api.py +207 -0
  1027. chia/wallet/wallet_pool_store.py +119 -0
  1028. chia/wallet/wallet_protocol.py +90 -0
  1029. chia/wallet/wallet_puzzle_store.py +396 -0
  1030. chia/wallet/wallet_retry_store.py +70 -0
  1031. chia/wallet/wallet_singleton_store.py +259 -0
  1032. chia/wallet/wallet_spend_bundle.py +25 -0
  1033. chia/wallet/wallet_state_manager.py +2819 -0
  1034. chia/wallet/wallet_transaction_store.py +496 -0
  1035. chia/wallet/wallet_user_store.py +110 -0
  1036. chia/wallet/wallet_weight_proof_handler.py +126 -0
  1037. chia_blockchain-2.5.1rc1.dist-info/LICENSE +201 -0
  1038. chia_blockchain-2.5.1rc1.dist-info/METADATA +156 -0
  1039. chia_blockchain-2.5.1rc1.dist-info/RECORD +1042 -0
  1040. chia_blockchain-2.5.1rc1.dist-info/WHEEL +4 -0
  1041. chia_blockchain-2.5.1rc1.dist-info/entry_points.txt +17 -0
  1042. mozilla-ca/cacert.pem +3611 -0
@@ -0,0 +1,1814 @@
1
+ from __future__ import annotations
2
+
3
+ from collections.abc import Sequence
4
+ from typing import Any, Optional, Union, cast
5
+
6
+ from chia.data_layer.data_layer_util import DLProof, VerifyProofResponse
7
+ from chia.data_layer.data_layer_wallet import Mirror, SingletonRecord
8
+ from chia.pools.pool_wallet_info import PoolWalletInfo
9
+ from chia.rpc.rpc_client import RpcClient
10
+ from chia.rpc.wallet_request_types import (
11
+ AddKey,
12
+ AddKeyResponse,
13
+ ApplySignatures,
14
+ ApplySignaturesResponse,
15
+ CancelOfferResponse,
16
+ CancelOffersResponse,
17
+ CATSpendResponse,
18
+ CheckDeleteKey,
19
+ CheckDeleteKeyResponse,
20
+ CombineCoins,
21
+ CombineCoinsResponse,
22
+ CreateNewDAOWalletResponse,
23
+ CreateOfferForIDsResponse,
24
+ CreateSignedTransactionsResponse,
25
+ DAOAddFundsToTreasuryResponse,
26
+ DAOCloseProposalResponse,
27
+ DAOCreateProposalResponse,
28
+ DAOExitLockupResponse,
29
+ DAOFreeCoinsFromFinishedProposalsResponse,
30
+ DAOSendToLockupResponse,
31
+ DAOVoteOnProposalResponse,
32
+ DeleteKey,
33
+ DIDGetCurrentCoinInfo,
34
+ DIDGetCurrentCoinInfoResponse,
35
+ DIDGetPubkey,
36
+ DIDGetPubkeyResponse,
37
+ DIDGetRecoveryInfo,
38
+ DIDGetRecoveryInfoResponse,
39
+ DIDMessageSpendResponse,
40
+ DIDTransferDIDResponse,
41
+ DIDUpdateMetadataResponse,
42
+ DIDUpdateRecoveryIDsResponse,
43
+ ExecuteSigningInstructions,
44
+ ExecuteSigningInstructionsResponse,
45
+ GatherSigningInfo,
46
+ GatherSigningInfoResponse,
47
+ GenerateMnemonicResponse,
48
+ GetCATListResponse,
49
+ GetHeightInfoResponse,
50
+ GetLoggedInFingerprintResponse,
51
+ GetNotifications,
52
+ GetNotificationsResponse,
53
+ GetOffersCountResponse,
54
+ GetPrivateKey,
55
+ GetPrivateKeyResponse,
56
+ GetPublicKeysResponse,
57
+ GetSyncStatusResponse,
58
+ GetTimestampForHeight,
59
+ GetTimestampForHeightResponse,
60
+ GetTransactionMemo,
61
+ GetTransactionMemoResponse,
62
+ LogIn,
63
+ LogInResponse,
64
+ NFTAddURIResponse,
65
+ NFTGetByDID,
66
+ NFTGetByDIDResponse,
67
+ NFTGetWalletsWithDIDsResponse,
68
+ NFTMintBulkResponse,
69
+ NFTMintNFTResponse,
70
+ NFTSetDIDBulk,
71
+ NFTSetDIDBulkResponse,
72
+ NFTSetNFTDIDResponse,
73
+ NFTSetNFTStatus,
74
+ NFTTransferBulk,
75
+ NFTTransferBulkResponse,
76
+ NFTTransferNFTResponse,
77
+ PushTransactions,
78
+ PushTransactionsResponse,
79
+ PushTX,
80
+ SendTransactionMultiResponse,
81
+ SendTransactionResponse,
82
+ SetWalletResyncOnStartup,
83
+ SplitCoins,
84
+ SplitCoinsResponse,
85
+ SubmitTransactions,
86
+ SubmitTransactionsResponse,
87
+ TakeOfferResponse,
88
+ VCAddProofs,
89
+ VCGet,
90
+ VCGetList,
91
+ VCGetListResponse,
92
+ VCGetProofsForRoot,
93
+ VCGetProofsForRootResponse,
94
+ VCGetResponse,
95
+ VCMint,
96
+ VCMintResponse,
97
+ VCRevoke,
98
+ VCRevokeResponse,
99
+ VCSpend,
100
+ VCSpendResponse,
101
+ VerifySignature,
102
+ VerifySignatureResponse,
103
+ )
104
+ from chia.types.blockchain_format.coin import Coin
105
+ from chia.types.blockchain_format.program import Program
106
+ from chia.types.blockchain_format.sized_bytes import bytes32
107
+ from chia.types.coin_record import CoinRecord
108
+ from chia.util.ints import uint16, uint32, uint64
109
+ from chia.wallet.conditions import Condition, ConditionValidTimes, conditions_to_json_dicts
110
+ from chia.wallet.puzzles.clawback.metadata import AutoClaimSettings
111
+ from chia.wallet.trade_record import TradeRecord
112
+ from chia.wallet.trading.offer import Offer
113
+ from chia.wallet.transaction_record import TransactionRecord
114
+ from chia.wallet.transaction_sorting import SortKey
115
+ from chia.wallet.util.clvm_streamable import json_deserialize_with_clvm_streamable
116
+ from chia.wallet.util.query_filter import TransactionTypeFilter
117
+ from chia.wallet.util.tx_config import CoinSelectionConfig, TXConfig
118
+ from chia.wallet.util.wallet_types import WalletType
119
+ from chia.wallet.wallet_coin_store import GetCoinRecords
120
+
121
+
122
+ def parse_result_transactions(result: dict[str, Any]) -> dict[str, Any]:
123
+ result["transaction"] = TransactionRecord.from_json_dict(result["transaction"])
124
+ result["transactions"] = [TransactionRecord.from_json_dict_convenience(tx) for tx in result["transactions"]]
125
+ if result["fee_transaction"]:
126
+ result["fee_transaction"] = TransactionRecord.from_json_dict(result["fee_transaction"])
127
+ return result
128
+
129
+
130
+ class WalletRpcClient(RpcClient):
131
+ """
132
+ Client to Chia RPC, connects to a local wallet. Uses HTTP/JSON, and converts back from
133
+ JSON into native python objects before returning. All api calls use POST requests.
134
+ Note that this is not the same as the peer protocol, or wallet protocol (which run Chia's
135
+ protocol on top of TCP), it's a separate protocol on top of HTTP that provides easy access
136
+ to the full node.
137
+ """
138
+
139
+ # Key Management APIs
140
+ async def log_in(self, request: LogIn) -> LogInResponse:
141
+ return LogInResponse.from_json_dict(await self.fetch("log_in", request.to_json_dict()))
142
+
143
+ async def get_logged_in_fingerprint(self) -> GetLoggedInFingerprintResponse:
144
+ return GetLoggedInFingerprintResponse.from_json_dict(await self.fetch("get_logged_in_fingerprint", {}))
145
+
146
+ async def get_public_keys(self) -> GetPublicKeysResponse:
147
+ return GetPublicKeysResponse.from_json_dict(await self.fetch("get_public_keys", {}))
148
+
149
+ async def get_private_key(self, request: GetPrivateKey) -> GetPrivateKeyResponse:
150
+ return GetPrivateKeyResponse.from_json_dict(await self.fetch("get_private_key", request.to_json_dict()))
151
+
152
+ async def generate_mnemonic(self) -> GenerateMnemonicResponse:
153
+ return GenerateMnemonicResponse.from_json_dict(await self.fetch("generate_mnemonic", {}))
154
+
155
+ async def add_key(self, request: AddKey) -> AddKeyResponse:
156
+ return AddKeyResponse.from_json_dict(await self.fetch("add_key", request.to_json_dict()))
157
+
158
+ async def delete_key(self, request: DeleteKey) -> None:
159
+ await self.fetch("delete_key", request.to_json_dict())
160
+
161
+ async def check_delete_key(self, request: CheckDeleteKey) -> CheckDeleteKeyResponse:
162
+ return CheckDeleteKeyResponse.from_json_dict(await self.fetch("check_delete_key", request.to_json_dict()))
163
+
164
+ async def delete_all_keys(self) -> None:
165
+ await self.fetch("delete_all_keys", {})
166
+
167
+ # Wallet Node APIs
168
+ async def set_wallet_resync_on_startup(self, request: SetWalletResyncOnStartup) -> None:
169
+ await self.fetch("set_wallet_resync_on_startup", request.to_json_dict())
170
+
171
+ async def get_sync_status(self) -> GetSyncStatusResponse:
172
+ return GetSyncStatusResponse.from_json_dict(await self.fetch("get_sync_status", {}))
173
+
174
+ async def get_height_info(self) -> GetHeightInfoResponse:
175
+ return GetHeightInfoResponse.from_json_dict(await self.fetch("get_height_info", {}))
176
+
177
+ async def push_tx(self, request: PushTX) -> None:
178
+ await self.fetch("push_tx", request.to_json_dict())
179
+
180
+ async def push_transactions(
181
+ self,
182
+ request: PushTransactions,
183
+ tx_config: TXConfig,
184
+ extra_conditions: tuple[Condition, ...] = tuple(),
185
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
186
+ ) -> PushTransactionsResponse:
187
+ return PushTransactionsResponse.from_json_dict(
188
+ await self.fetch(
189
+ "push_transactions", request.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
190
+ )
191
+ )
192
+
193
+ async def get_timestamp_for_height(self, request: GetTimestampForHeight) -> GetTimestampForHeightResponse:
194
+ return GetTimestampForHeightResponse.from_json_dict(
195
+ await self.fetch("get_timestamp_for_height", request.to_json_dict())
196
+ )
197
+
198
+ async def set_auto_claim(self, request: AutoClaimSettings) -> AutoClaimSettings:
199
+ return AutoClaimSettings.from_json_dict(await self.fetch("set_auto_claim", {**request.to_json_dict()}))
200
+
201
+ async def get_auto_claim(self) -> AutoClaimSettings:
202
+ return AutoClaimSettings.from_json_dict(await self.fetch("get_auto_claim", {}))
203
+
204
+ # Wallet Management APIs
205
+ async def get_wallets(self, wallet_type: Optional[WalletType] = None) -> list[dict[str, Any]]:
206
+ if wallet_type is None:
207
+ request = {}
208
+ else:
209
+ request = {"type": wallet_type}
210
+ response = await self.fetch("get_wallets", request)
211
+ # TODO: casting due to lack of type checked deserialization
212
+ return cast(list[dict[str, Any]], response["wallets"])
213
+
214
+ # Wallet APIs
215
+ async def get_wallet_balance(self, wallet_id: int) -> dict[str, Any]:
216
+ request = {"wallet_id": wallet_id}
217
+ response = await self.fetch("get_wallet_balance", request)
218
+ # TODO: casting due to lack of type checked deserialization
219
+ return cast(dict[str, Any], response["wallet_balance"])
220
+
221
+ async def get_wallet_balances(self, wallet_ids: Optional[list[int]] = None) -> dict[str, dict[str, Any]]:
222
+ request = {"wallet_ids": wallet_ids}
223
+ response = await self.fetch("get_wallet_balances", request)
224
+ # TODO: casting due to lack of type checked deserialization
225
+ return cast(dict[str, dict[str, Any]], response["wallet_balances"])
226
+
227
+ async def get_transaction(self, transaction_id: bytes32) -> TransactionRecord:
228
+ request = {"transaction_id": transaction_id.hex()}
229
+ response = await self.fetch("get_transaction", request)
230
+ return TransactionRecord.from_json_dict_convenience(response["transaction"])
231
+
232
+ async def get_transactions(
233
+ self,
234
+ wallet_id: int,
235
+ start: Optional[int] = None,
236
+ end: Optional[int] = None,
237
+ sort_key: Optional[SortKey] = None,
238
+ reverse: bool = False,
239
+ to_address: Optional[str] = None,
240
+ type_filter: Optional[TransactionTypeFilter] = None,
241
+ confirmed: Optional[bool] = None,
242
+ ) -> list[TransactionRecord]:
243
+ request: dict[str, Any] = {"wallet_id": wallet_id}
244
+
245
+ if start is not None:
246
+ request["start"] = start
247
+ if end is not None:
248
+ request["end"] = end
249
+ if sort_key is not None:
250
+ request["sort_key"] = sort_key.name
251
+ request["reverse"] = reverse
252
+
253
+ if to_address is not None:
254
+ request["to_address"] = to_address
255
+
256
+ if type_filter is not None:
257
+ request["type_filter"] = type_filter.to_json_dict()
258
+
259
+ if confirmed is not None:
260
+ request["confirmed"] = confirmed
261
+
262
+ res = await self.fetch("get_transactions", request)
263
+ return [TransactionRecord.from_json_dict_convenience(tx) for tx in res["transactions"]]
264
+
265
+ async def get_transaction_count(
266
+ self, wallet_id: int, confirmed: Optional[bool] = None, type_filter: Optional[TransactionTypeFilter] = None
267
+ ) -> int:
268
+ request: dict[str, Any] = {"wallet_id": wallet_id}
269
+ if type_filter is not None:
270
+ request["type_filter"] = type_filter.to_json_dict()
271
+ if confirmed is not None:
272
+ request["confirmed"] = confirmed
273
+ res = await self.fetch("get_transaction_count", request)
274
+ # TODO: casting due to lack of type checked deserialization
275
+ return cast(int, res["count"])
276
+
277
+ async def get_next_address(self, wallet_id: int, new_address: bool) -> str:
278
+ request = {"wallet_id": wallet_id, "new_address": new_address}
279
+ response = await self.fetch("get_next_address", request)
280
+ # TODO: casting due to lack of type checked deserialization
281
+ return cast(str, response["address"])
282
+
283
+ async def send_transaction(
284
+ self,
285
+ wallet_id: int,
286
+ amount: uint64,
287
+ address: str,
288
+ tx_config: TXConfig,
289
+ fee: uint64 = uint64(0),
290
+ memos: Optional[list[str]] = None,
291
+ puzzle_decorator_override: Optional[list[dict[str, Union[str, int, bool]]]] = None,
292
+ extra_conditions: tuple[Condition, ...] = tuple(),
293
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
294
+ push: bool = True,
295
+ ) -> SendTransactionResponse:
296
+ request = {
297
+ "wallet_id": wallet_id,
298
+ "amount": amount,
299
+ "address": address,
300
+ "fee": fee,
301
+ "puzzle_decorator": puzzle_decorator_override,
302
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
303
+ "push": push,
304
+ **tx_config.to_json_dict(),
305
+ **timelock_info.to_json_dict(),
306
+ }
307
+ if memos is not None:
308
+ request["memos"] = memos
309
+ response = await self.fetch("send_transaction", request)
310
+ return json_deserialize_with_clvm_streamable(response, SendTransactionResponse)
311
+
312
+ async def send_transaction_multi(
313
+ self,
314
+ wallet_id: int,
315
+ additions: list[dict[str, Any]],
316
+ tx_config: TXConfig,
317
+ coins: Optional[list[Coin]] = None,
318
+ fee: uint64 = uint64(0),
319
+ push: bool = True,
320
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
321
+ ) -> SendTransactionMultiResponse:
322
+ # Converts bytes to hex for puzzle hashes
323
+ additions_hex = []
324
+ for ad in additions:
325
+ additions_hex.append({"amount": ad["amount"], "puzzle_hash": ad["puzzle_hash"].hex()})
326
+ if "memos" in ad:
327
+ additions_hex[-1]["memos"] = ad["memos"]
328
+ request = {
329
+ "wallet_id": wallet_id,
330
+ "additions": additions_hex,
331
+ "fee": fee,
332
+ "push": push,
333
+ **tx_config.to_json_dict(),
334
+ **timelock_info.to_json_dict(),
335
+ }
336
+ if coins is not None and len(coins) > 0:
337
+ coins_json = [c.to_json_dict() for c in coins]
338
+ request["coins"] = coins_json
339
+ response = await self.fetch("send_transaction_multi", request)
340
+ return json_deserialize_with_clvm_streamable(response, SendTransactionMultiResponse)
341
+
342
+ async def spend_clawback_coins(
343
+ self,
344
+ coin_ids: list[bytes32],
345
+ fee: int = 0,
346
+ force: bool = False,
347
+ push: bool = True,
348
+ extra_conditions: tuple[Condition, ...] = tuple(),
349
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
350
+ ) -> dict[str, Any]:
351
+ request = {
352
+ "coin_ids": [cid.hex() for cid in coin_ids],
353
+ "fee": fee,
354
+ "force": force,
355
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
356
+ "push": push,
357
+ **timelock_info.to_json_dict(),
358
+ }
359
+ response = await self.fetch("spend_clawback_coins", request)
360
+ return response
361
+
362
+ async def delete_unconfirmed_transactions(self, wallet_id: int) -> None:
363
+ await self.fetch("delete_unconfirmed_transactions", {"wallet_id": wallet_id})
364
+
365
+ async def get_current_derivation_index(self) -> str:
366
+ response = await self.fetch("get_current_derivation_index", {})
367
+ index = response["index"]
368
+ return str(index)
369
+
370
+ async def extend_derivation_index(self, index: int) -> str:
371
+ response = await self.fetch("extend_derivation_index", {"index": index})
372
+ updated_index = response["index"]
373
+ return str(updated_index)
374
+
375
+ async def get_farmed_amount(self) -> dict[str, Any]:
376
+ return await self.fetch("get_farmed_amount", {})
377
+
378
+ async def create_signed_transactions(
379
+ self,
380
+ additions: list[dict[str, Any]],
381
+ tx_config: TXConfig,
382
+ coins: Optional[list[Coin]] = None,
383
+ fee: uint64 = uint64(0),
384
+ wallet_id: Optional[int] = None,
385
+ extra_conditions: tuple[Condition, ...] = tuple(),
386
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
387
+ push: bool = False,
388
+ ) -> CreateSignedTransactionsResponse:
389
+ # Converts bytes to hex for puzzle hashes
390
+ additions_hex = []
391
+ for ad in additions:
392
+ additions_hex.append({"amount": ad["amount"], "puzzle_hash": ad["puzzle_hash"].hex()})
393
+ if "memos" in ad:
394
+ additions_hex[-1]["memos"] = ad["memos"]
395
+
396
+ request = {
397
+ "additions": additions_hex,
398
+ "fee": fee,
399
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
400
+ "push": push,
401
+ **tx_config.to_json_dict(),
402
+ **timelock_info.to_json_dict(),
403
+ }
404
+
405
+ if coins is not None and len(coins) > 0:
406
+ coins_json = [c.to_json_dict() for c in coins]
407
+ request["coins"] = coins_json
408
+
409
+ if wallet_id:
410
+ request["wallet_id"] = wallet_id
411
+
412
+ response = await self.fetch("create_signed_transaction", request)
413
+ return json_deserialize_with_clvm_streamable(response, CreateSignedTransactionsResponse)
414
+
415
+ async def select_coins(self, amount: int, wallet_id: int, coin_selection_config: CoinSelectionConfig) -> list[Coin]:
416
+ request = {"amount": amount, "wallet_id": wallet_id, **coin_selection_config.to_json_dict()}
417
+ response = await self.fetch("select_coins", request)
418
+ return [Coin.from_json_dict(coin) for coin in response["coins"]]
419
+
420
+ async def get_coin_records(self, request: GetCoinRecords) -> dict[str, Any]:
421
+ return await self.fetch("get_coin_records", request.to_json_dict())
422
+
423
+ async def get_spendable_coins(
424
+ self, wallet_id: int, coin_selection_config: CoinSelectionConfig
425
+ ) -> tuple[list[CoinRecord], list[CoinRecord], list[Coin]]:
426
+ """
427
+ We return a tuple containing: (confirmed records, unconfirmed removals, unconfirmed additions)
428
+ """
429
+ request = {"wallet_id": wallet_id, **coin_selection_config.to_json_dict()}
430
+ response = await self.fetch("get_spendable_coins", request)
431
+ confirmed_wrs = [CoinRecord.from_json_dict(coin) for coin in response["confirmed_records"]]
432
+ unconfirmed_removals = [CoinRecord.from_json_dict(coin) for coin in response["unconfirmed_removals"]]
433
+ unconfirmed_additions = [Coin.from_json_dict(coin) for coin in response["unconfirmed_additions"]]
434
+ return confirmed_wrs, unconfirmed_removals, unconfirmed_additions
435
+
436
+ async def get_coin_records_by_names(
437
+ self,
438
+ names: list[bytes32],
439
+ include_spent_coins: bool = True,
440
+ start_height: Optional[int] = None,
441
+ end_height: Optional[int] = None,
442
+ ) -> list[CoinRecord]:
443
+ names_hex = [name.hex() for name in names]
444
+ request = {"names": names_hex, "include_spent_coins": include_spent_coins}
445
+ if start_height is not None:
446
+ request["start_height"] = start_height
447
+ if end_height is not None:
448
+ request["end_height"] = end_height
449
+
450
+ response = await self.fetch("get_coin_records_by_names", request)
451
+ return [CoinRecord.from_json_dict(cr) for cr in response["coin_records"]]
452
+
453
+ # DID wallet
454
+ async def create_new_did_wallet(
455
+ self,
456
+ amount: int,
457
+ tx_config: TXConfig,
458
+ fee: int = 0,
459
+ name: Optional[str] = "DID Wallet",
460
+ backup_ids: list[str] = [],
461
+ required_num: int = 0,
462
+ type: str = "new",
463
+ backup_data: str = "",
464
+ push: bool = True,
465
+ extra_conditions: tuple[Condition, ...] = tuple(),
466
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
467
+ ) -> dict[str, Any]:
468
+ request = {
469
+ "wallet_type": "did_wallet",
470
+ "did_type": type,
471
+ "backup_dids": backup_ids,
472
+ "num_of_backup_ids_needed": required_num,
473
+ "amount": amount,
474
+ "fee": fee,
475
+ "wallet_name": name,
476
+ "push": push,
477
+ "backup_data": backup_data,
478
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
479
+ **tx_config.to_json_dict(),
480
+ **timelock_info.to_json_dict(),
481
+ }
482
+ response = await self.fetch("create_new_wallet", request)
483
+ return response
484
+
485
+ async def get_did_id(self, wallet_id: int) -> dict[str, Any]:
486
+ request = {"wallet_id": wallet_id}
487
+ response = await self.fetch("did_get_did", request)
488
+ return response
489
+
490
+ async def get_did_info(self, coin_id: str, latest: bool) -> dict[str, Any]:
491
+ request = {"coin_id": coin_id, "latest": latest}
492
+ response = await self.fetch("did_get_info", request)
493
+ return response
494
+
495
+ async def create_did_backup_file(self, wallet_id: int, filename: str) -> dict[str, Any]:
496
+ request = {"wallet_id": wallet_id, "filename": filename}
497
+ response = await self.fetch("did_create_backup_file", request)
498
+ return response
499
+
500
+ async def update_did_recovery_list(
501
+ self,
502
+ wallet_id: int,
503
+ recovery_list: list[str],
504
+ num_verification: int,
505
+ tx_config: TXConfig,
506
+ extra_conditions: tuple[Condition, ...] = tuple(),
507
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
508
+ push: bool = True,
509
+ ) -> DIDUpdateRecoveryIDsResponse:
510
+ request = {
511
+ "wallet_id": wallet_id,
512
+ "new_list": recovery_list,
513
+ "num_verifications_required": num_verification,
514
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
515
+ "push": push,
516
+ **tx_config.to_json_dict(),
517
+ **timelock_info.to_json_dict(),
518
+ }
519
+ response = await self.fetch("did_update_recovery_ids", request)
520
+ return json_deserialize_with_clvm_streamable(response, DIDUpdateRecoveryIDsResponse)
521
+
522
+ async def get_did_recovery_list(self, wallet_id: int) -> dict[str, Any]:
523
+ request = {"wallet_id": wallet_id}
524
+ response = await self.fetch("did_get_recovery_list", request)
525
+ return response
526
+
527
+ async def did_message_spend(
528
+ self,
529
+ wallet_id: int,
530
+ tx_config: TXConfig,
531
+ extra_conditions: tuple[Condition, ...] = tuple(),
532
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
533
+ push: bool = False,
534
+ ) -> DIDMessageSpendResponse:
535
+ request = {
536
+ "wallet_id": wallet_id,
537
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
538
+ "push": push,
539
+ **tx_config.to_json_dict(),
540
+ **timelock_info.to_json_dict(),
541
+ }
542
+ response = await self.fetch("did_message_spend", request)
543
+ return json_deserialize_with_clvm_streamable(response, DIDMessageSpendResponse)
544
+
545
+ async def update_did_metadata(
546
+ self,
547
+ wallet_id: int,
548
+ metadata: dict[str, Any],
549
+ tx_config: TXConfig,
550
+ extra_conditions: tuple[Condition, ...] = tuple(),
551
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
552
+ push: bool = True,
553
+ ) -> DIDUpdateMetadataResponse:
554
+ request = {
555
+ "wallet_id": wallet_id,
556
+ "metadata": metadata,
557
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
558
+ "push": push,
559
+ **tx_config.to_json_dict(),
560
+ **timelock_info.to_json_dict(),
561
+ }
562
+ response = await self.fetch("did_update_metadata", request)
563
+ return json_deserialize_with_clvm_streamable(response, DIDUpdateMetadataResponse)
564
+
565
+ async def get_did_pubkey(self, request: DIDGetPubkey) -> DIDGetPubkeyResponse:
566
+ return DIDGetPubkeyResponse.from_json_dict(await self.fetch("did_get_pubkey", request.to_json_dict()))
567
+
568
+ async def get_did_metadata(self, wallet_id: int) -> dict[str, Any]:
569
+ request = {"wallet_id": wallet_id}
570
+ response = await self.fetch("did_get_metadata", request)
571
+ return response
572
+
573
+ async def find_lost_did(
574
+ self,
575
+ coin_id: str,
576
+ recovery_list_hash: Optional[str],
577
+ metadata: Optional[dict[str, Any]],
578
+ num_verification: Optional[int],
579
+ ) -> dict[str, Any]:
580
+ request: dict[str, Any] = {"coin_id": coin_id}
581
+ if recovery_list_hash is not None:
582
+ request["recovery_list_hash"] = recovery_list_hash
583
+ if metadata is not None:
584
+ request["metadata"] = (metadata,)
585
+ if num_verification is not None:
586
+ request["num_verification"] = num_verification
587
+ response = await self.fetch("did_find_lost_did", request)
588
+ return response
589
+
590
+ async def create_new_did_wallet_from_recovery(self, filename: str) -> dict[str, Any]:
591
+ request = {"wallet_type": "did_wallet", "did_type": "recovery", "filename": filename}
592
+ response = await self.fetch("create_new_wallet", request)
593
+ return response
594
+
595
+ async def did_create_attest(
596
+ self,
597
+ wallet_id: int,
598
+ coin_name: str,
599
+ pubkey: str,
600
+ puzhash: str,
601
+ file_name: str,
602
+ extra_conditions: tuple[Condition, ...] = tuple(),
603
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
604
+ ) -> dict[str, Any]:
605
+ request = {
606
+ "wallet_id": wallet_id,
607
+ "coin_name": coin_name,
608
+ "pubkey": pubkey,
609
+ "puzhash": puzhash,
610
+ "filename": file_name,
611
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
612
+ **timelock_info.to_json_dict(),
613
+ }
614
+ response = await self.fetch("did_create_attest", request)
615
+ return response
616
+
617
+ async def did_get_recovery_info(self, request: DIDGetRecoveryInfo) -> DIDGetRecoveryInfoResponse:
618
+ return DIDGetRecoveryInfoResponse.from_json_dict(
619
+ await self.fetch("did_get_information_needed_for_recovery", request.to_json_dict())
620
+ )
621
+
622
+ async def did_get_current_coin_info(self, request: DIDGetCurrentCoinInfo) -> DIDGetCurrentCoinInfoResponse:
623
+ return DIDGetCurrentCoinInfoResponse.from_json_dict(
624
+ await self.fetch("did_get_current_coin_info", request.to_json_dict())
625
+ )
626
+
627
+ async def did_recovery_spend(self, wallet_id: int, attest_filenames: str) -> dict[str, Any]:
628
+ request = {"wallet_id": wallet_id, "attest_filenames": attest_filenames}
629
+ response = await self.fetch("did_recovery_spend", request)
630
+ return response
631
+
632
+ async def did_transfer_did(
633
+ self,
634
+ wallet_id: int,
635
+ address: str,
636
+ fee: int,
637
+ with_recovery: bool,
638
+ tx_config: TXConfig,
639
+ extra_conditions: tuple[Condition, ...] = tuple(),
640
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
641
+ push: bool = True,
642
+ ) -> DIDTransferDIDResponse:
643
+ request = {
644
+ "wallet_id": wallet_id,
645
+ "inner_address": address,
646
+ "fee": fee,
647
+ "with_recovery_info": with_recovery,
648
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
649
+ "push": push,
650
+ **tx_config.to_json_dict(),
651
+ **timelock_info.to_json_dict(),
652
+ }
653
+ response = await self.fetch("did_transfer_did", request)
654
+ return json_deserialize_with_clvm_streamable(response, DIDTransferDIDResponse)
655
+
656
+ async def did_set_wallet_name(self, wallet_id: int, name: str) -> dict[str, Any]:
657
+ request = {"wallet_id": wallet_id, "name": name}
658
+ response = await self.fetch("did_set_wallet_name", request)
659
+ return response
660
+
661
+ async def did_get_wallet_name(self, wallet_id: int) -> dict[str, Any]:
662
+ request = {"wallet_id": wallet_id}
663
+ response = await self.fetch("did_get_wallet_name", request)
664
+ return response
665
+
666
+ # TODO: test all invocations of create_new_pool_wallet with new fee arg.
667
+ async def create_new_pool_wallet(
668
+ self,
669
+ target_puzzlehash: Optional[bytes32],
670
+ pool_url: Optional[str],
671
+ relative_lock_height: uint32,
672
+ backup_host: str,
673
+ mode: str,
674
+ state: str,
675
+ fee: uint64,
676
+ p2_singleton_delay_time: Optional[uint64] = None,
677
+ p2_singleton_delayed_ph: Optional[bytes32] = None,
678
+ extra_conditions: tuple[Condition, ...] = tuple(),
679
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
680
+ ) -> TransactionRecord:
681
+ request = {
682
+ "wallet_type": "pool_wallet",
683
+ "mode": mode,
684
+ "initial_target_state": {
685
+ "target_puzzle_hash": target_puzzlehash.hex() if target_puzzlehash else None,
686
+ "relative_lock_height": relative_lock_height,
687
+ "pool_url": pool_url,
688
+ "state": state,
689
+ },
690
+ "fee": fee,
691
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
692
+ **timelock_info.to_json_dict(),
693
+ }
694
+ if p2_singleton_delay_time is not None:
695
+ request["p2_singleton_delay_time"] = p2_singleton_delay_time
696
+ if p2_singleton_delayed_ph is not None:
697
+ request["p2_singleton_delayed_ph"] = p2_singleton_delayed_ph.hex()
698
+ res = await self.fetch("create_new_wallet", request)
699
+ return TransactionRecord.from_json_dict(res["transaction"])
700
+
701
+ async def pw_self_pool(self, wallet_id: int, fee: uint64) -> dict[str, Any]:
702
+ reply = await self.fetch("pw_self_pool", {"wallet_id": wallet_id, "fee": fee})
703
+ reply = parse_result_transactions(reply)
704
+ return reply
705
+
706
+ async def pw_join_pool(
707
+ self, wallet_id: int, target_puzzlehash: bytes32, pool_url: str, relative_lock_height: uint32, fee: uint64
708
+ ) -> dict[str, Any]:
709
+ request = {
710
+ "wallet_id": int(wallet_id),
711
+ "target_puzzlehash": target_puzzlehash.hex(),
712
+ "relative_lock_height": relative_lock_height,
713
+ "pool_url": pool_url,
714
+ "fee": fee,
715
+ }
716
+ reply = await self.fetch("pw_join_pool", request)
717
+ reply = parse_result_transactions(reply)
718
+ return reply
719
+
720
+ async def pw_absorb_rewards(
721
+ self, wallet_id: int, fee: uint64 = uint64(0), max_spends_in_tx: Optional[int] = None
722
+ ) -> dict[str, Any]:
723
+ reply = await self.fetch(
724
+ "pw_absorb_rewards", {"wallet_id": wallet_id, "fee": fee, "max_spends_in_tx": max_spends_in_tx}
725
+ )
726
+ reply["state"] = PoolWalletInfo.from_json_dict(reply["state"])
727
+ reply = parse_result_transactions(reply)
728
+ return reply
729
+
730
+ async def pw_status(self, wallet_id: int) -> tuple[PoolWalletInfo, list[TransactionRecord]]:
731
+ json_dict = await self.fetch("pw_status", {"wallet_id": wallet_id})
732
+ return (
733
+ PoolWalletInfo.from_json_dict(json_dict["state"]),
734
+ [TransactionRecord.from_json_dict(tr) for tr in json_dict["unconfirmed_transactions"]],
735
+ )
736
+
737
+ # CATS
738
+ async def create_new_cat_and_wallet(
739
+ self, amount: uint64, fee: uint64 = uint64(0), test: bool = False
740
+ ) -> dict[str, Any]:
741
+ request = {"wallet_type": "cat_wallet", "mode": "new", "amount": amount, "fee": fee, "test": test}
742
+ return await self.fetch("create_new_wallet", request)
743
+
744
+ async def create_wallet_for_existing_cat(self, asset_id: bytes) -> dict[str, Any]:
745
+ request = {"wallet_type": "cat_wallet", "asset_id": asset_id.hex(), "mode": "existing"}
746
+ return await self.fetch("create_new_wallet", request)
747
+
748
+ async def get_cat_asset_id(self, wallet_id: int) -> bytes32:
749
+ request = {"wallet_id": wallet_id}
750
+ return bytes32.from_hexstr((await self.fetch("cat_get_asset_id", request))["asset_id"])
751
+
752
+ async def get_stray_cats(self) -> list[dict[str, Any]]:
753
+ response = await self.fetch("get_stray_cats", {})
754
+ # TODO: casting due to lack of type checked deserialization
755
+ return cast(list[dict[str, Any]], response["stray_cats"])
756
+
757
+ async def cat_asset_id_to_name(self, asset_id: bytes32) -> Optional[tuple[Optional[uint32], str]]:
758
+ request = {"asset_id": asset_id.hex()}
759
+ try:
760
+ res = await self.fetch("cat_asset_id_to_name", request)
761
+ except ValueError:
762
+ return None
763
+
764
+ wallet_id: Optional[uint32] = None if res["wallet_id"] is None else uint32(int(res["wallet_id"]))
765
+ return wallet_id, res["name"]
766
+
767
+ async def get_cat_name(self, wallet_id: int) -> str:
768
+ request = {"wallet_id": wallet_id}
769
+ response = await self.fetch("cat_get_name", request)
770
+ # TODO: casting due to lack of type checked deserialization
771
+ return cast(str, response["name"])
772
+
773
+ async def set_cat_name(self, wallet_id: int, name: str) -> None:
774
+ request: dict[str, Any] = {
775
+ "wallet_id": wallet_id,
776
+ "name": name,
777
+ }
778
+ await self.fetch("cat_set_name", request)
779
+
780
+ async def cat_spend(
781
+ self,
782
+ wallet_id: int,
783
+ tx_config: TXConfig,
784
+ amount: Optional[uint64] = None,
785
+ inner_address: Optional[str] = None,
786
+ fee: uint64 = uint64(0),
787
+ memos: Optional[list[str]] = None,
788
+ additions: Optional[list[dict[str, Any]]] = None,
789
+ removals: Optional[list[Coin]] = None,
790
+ cat_discrepancy: Optional[tuple[int, Program, Program]] = None, # (extra_delta, tail_reveal, tail_solution)
791
+ extra_conditions: tuple[Condition, ...] = tuple(),
792
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
793
+ push: bool = True,
794
+ ) -> CATSpendResponse:
795
+ send_dict: dict[str, Any] = {
796
+ "wallet_id": wallet_id,
797
+ "fee": fee,
798
+ "memos": memos if memos is not None else [],
799
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
800
+ "push": push,
801
+ **tx_config.to_json_dict(),
802
+ **timelock_info.to_json_dict(),
803
+ }
804
+ if amount is not None and inner_address is not None:
805
+ send_dict["amount"] = amount
806
+ send_dict["inner_address"] = inner_address
807
+ elif additions is not None:
808
+ additions_hex = []
809
+ for ad in additions:
810
+ additions_hex.append({"amount": ad["amount"], "puzzle_hash": ad["puzzle_hash"].hex()})
811
+ if "memos" in ad:
812
+ additions_hex[-1]["memos"] = ad["memos"]
813
+ send_dict["additions"] = additions_hex
814
+ else:
815
+ raise ValueError("Must specify either amount and inner_address or additions")
816
+ if removals is not None and len(removals) > 0:
817
+ send_dict["coins"] = [c.to_json_dict() for c in removals]
818
+ if cat_discrepancy is not None:
819
+ send_dict["extra_delta"] = cat_discrepancy[0]
820
+ send_dict["tail_reveal"] = bytes(cat_discrepancy[1]).hex()
821
+ send_dict["tail_solution"] = bytes(cat_discrepancy[2]).hex()
822
+ res = await self.fetch("cat_spend", send_dict)
823
+ return json_deserialize_with_clvm_streamable(res, CATSpendResponse)
824
+
825
+ # Offers
826
+ async def create_offer_for_ids(
827
+ self,
828
+ offer_dict: dict[Union[uint32, str], int],
829
+ tx_config: TXConfig,
830
+ driver_dict: Optional[dict[str, Any]] = None,
831
+ solver: Optional[dict[str, Any]] = None,
832
+ fee: int = 0,
833
+ validate_only: bool = False,
834
+ extra_conditions: tuple[Condition, ...] = tuple(),
835
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
836
+ ) -> CreateOfferForIDsResponse:
837
+ send_dict: dict[str, int] = {str(key): value for key, value in offer_dict.items()}
838
+
839
+ req = {
840
+ "offer": send_dict,
841
+ "validate_only": validate_only,
842
+ "fee": fee,
843
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
844
+ **tx_config.to_json_dict(),
845
+ **timelock_info.to_json_dict(),
846
+ }
847
+ if driver_dict is not None:
848
+ req["driver_dict"] = driver_dict
849
+ if solver is not None:
850
+ req["solver"] = solver
851
+ res = await self.fetch("create_offer_for_ids", req)
852
+ return json_deserialize_with_clvm_streamable(res, CreateOfferForIDsResponse)
853
+
854
+ async def get_offer_summary(
855
+ self, offer: Offer, advanced: bool = False
856
+ ) -> tuple[bytes32, dict[str, dict[str, int]]]:
857
+ res = await self.fetch("get_offer_summary", {"offer": offer.to_bech32(), "advanced": advanced})
858
+ return bytes32.from_hexstr(res["id"]), res["summary"]
859
+
860
+ async def check_offer_validity(self, offer: Offer) -> tuple[bytes32, bool]:
861
+ res = await self.fetch("check_offer_validity", {"offer": offer.to_bech32()})
862
+ return bytes32.from_hexstr(res["id"]), res["valid"]
863
+
864
+ async def take_offer(
865
+ self,
866
+ offer: Offer,
867
+ tx_config: TXConfig,
868
+ solver: Optional[dict[str, Any]] = None,
869
+ fee: int = 0,
870
+ extra_conditions: tuple[Condition, ...] = tuple(),
871
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
872
+ push: bool = True,
873
+ ) -> TakeOfferResponse:
874
+ req = {
875
+ "offer": offer.to_bech32(),
876
+ "fee": fee,
877
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
878
+ "push": push,
879
+ **tx_config.to_json_dict(),
880
+ **timelock_info.to_json_dict(),
881
+ }
882
+ if solver is not None:
883
+ req["solver"] = solver
884
+ res = await self.fetch("take_offer", req)
885
+ return json_deserialize_with_clvm_streamable(res, TakeOfferResponse)
886
+
887
+ async def get_offer(self, trade_id: bytes32, file_contents: bool = False) -> TradeRecord:
888
+ res = await self.fetch("get_offer", {"trade_id": trade_id.hex(), "file_contents": file_contents})
889
+ offer_str = bytes(Offer.from_bech32(res["offer"])).hex() if file_contents else ""
890
+ return TradeRecord.from_json_dict_convenience(res["trade_record"], offer_str)
891
+
892
+ async def get_all_offers(
893
+ self,
894
+ start: int = 0,
895
+ end: int = 50,
896
+ sort_key: Optional[str] = None,
897
+ reverse: bool = False,
898
+ file_contents: bool = False,
899
+ exclude_my_offers: bool = False,
900
+ exclude_taken_offers: bool = False,
901
+ include_completed: bool = False,
902
+ ) -> list[TradeRecord]:
903
+ res = await self.fetch(
904
+ "get_all_offers",
905
+ {
906
+ "start": start,
907
+ "end": end,
908
+ "sort_key": sort_key,
909
+ "reverse": reverse,
910
+ "file_contents": file_contents,
911
+ "exclude_my_offers": exclude_my_offers,
912
+ "exclude_taken_offers": exclude_taken_offers,
913
+ "include_completed": include_completed,
914
+ },
915
+ )
916
+
917
+ records = []
918
+ if file_contents:
919
+ optional_offers = [bytes(Offer.from_bech32(o)).hex() for o in res["offers"]]
920
+ else:
921
+ optional_offers = [""] * len(res["trade_records"])
922
+ for record, offer in zip(res["trade_records"], optional_offers):
923
+ records.append(TradeRecord.from_json_dict_convenience(record, offer))
924
+
925
+ return records
926
+
927
+ async def get_offers_count(self) -> GetOffersCountResponse:
928
+ return GetOffersCountResponse.from_json_dict(await self.fetch("get_offers_count", {}))
929
+
930
+ async def cancel_offer(
931
+ self,
932
+ trade_id: bytes32,
933
+ tx_config: TXConfig,
934
+ fee: int = 0,
935
+ secure: bool = True,
936
+ extra_conditions: tuple[Condition, ...] = tuple(),
937
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
938
+ push: bool = True,
939
+ ) -> CancelOfferResponse:
940
+ res = await self.fetch(
941
+ "cancel_offer",
942
+ {
943
+ "trade_id": trade_id.hex(),
944
+ "secure": secure,
945
+ "fee": fee,
946
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
947
+ "push": push,
948
+ **tx_config.to_json_dict(),
949
+ **timelock_info.to_json_dict(),
950
+ },
951
+ )
952
+
953
+ return json_deserialize_with_clvm_streamable(res, CancelOfferResponse)
954
+
955
+ async def cancel_offers(
956
+ self,
957
+ tx_config: TXConfig,
958
+ batch_fee: int = 0,
959
+ secure: bool = True,
960
+ batch_size: int = 5,
961
+ cancel_all: bool = False,
962
+ asset_id: Optional[bytes32] = None,
963
+ extra_conditions: tuple[Condition, ...] = tuple(),
964
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
965
+ push: bool = True,
966
+ ) -> CancelOffersResponse:
967
+ res = await self.fetch(
968
+ "cancel_offers",
969
+ {
970
+ "secure": secure,
971
+ "batch_fee": batch_fee,
972
+ "batch_size": batch_size,
973
+ "cancel_all": cancel_all,
974
+ "asset_id": None if asset_id is None else asset_id.hex(),
975
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
976
+ "push": push,
977
+ **tx_config.to_json_dict(),
978
+ **timelock_info.to_json_dict(),
979
+ },
980
+ )
981
+
982
+ return json_deserialize_with_clvm_streamable(res, CancelOffersResponse)
983
+
984
+ async def get_cat_list(self) -> GetCATListResponse:
985
+ return GetCATListResponse.from_json_dict(await self.fetch("get_cat_list", {}))
986
+
987
+ # NFT wallet
988
+ async def create_new_nft_wallet(self, did_id: Optional[str], name: Optional[str] = None) -> dict[str, Any]:
989
+ request = {"wallet_type": "nft_wallet", "did_id": did_id, "name": name}
990
+ response = await self.fetch("create_new_wallet", request)
991
+ return response
992
+
993
+ async def mint_nft(
994
+ self,
995
+ wallet_id: int,
996
+ royalty_address: Optional[str],
997
+ target_address: Optional[str],
998
+ hash: str,
999
+ uris: list[str],
1000
+ tx_config: TXConfig,
1001
+ meta_hash: Optional[str] = "",
1002
+ meta_uris: list[str] = [],
1003
+ license_hash: Optional[str] = "",
1004
+ license_uris: list[str] = [],
1005
+ edition_total: Optional[int] = 1,
1006
+ edition_number: Optional[int] = 1,
1007
+ fee: int = 0,
1008
+ royalty_percentage: int = 0,
1009
+ did_id: Optional[str] = None,
1010
+ extra_conditions: tuple[Condition, ...] = tuple(),
1011
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1012
+ push: bool = True,
1013
+ ) -> NFTMintNFTResponse:
1014
+ request = {
1015
+ "wallet_id": wallet_id,
1016
+ "royalty_address": royalty_address,
1017
+ "target_address": target_address,
1018
+ "hash": hash,
1019
+ "uris": uris,
1020
+ "meta_hash": meta_hash,
1021
+ "meta_uris": meta_uris,
1022
+ "license_hash": license_hash,
1023
+ "license_uris": license_uris,
1024
+ "edition_number": edition_number,
1025
+ "edition_total": edition_total,
1026
+ "royalty_percentage": royalty_percentage,
1027
+ "did_id": did_id,
1028
+ "fee": fee,
1029
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1030
+ "push": push,
1031
+ **tx_config.to_json_dict(),
1032
+ **timelock_info.to_json_dict(),
1033
+ }
1034
+ response = await self.fetch("nft_mint_nft", request)
1035
+ return json_deserialize_with_clvm_streamable(response, NFTMintNFTResponse)
1036
+
1037
+ async def add_uri_to_nft(
1038
+ self,
1039
+ wallet_id: int,
1040
+ nft_coin_id: str,
1041
+ key: str,
1042
+ uri: str,
1043
+ fee: int,
1044
+ tx_config: TXConfig,
1045
+ extra_conditions: tuple[Condition, ...] = tuple(),
1046
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1047
+ push: bool = True,
1048
+ ) -> NFTAddURIResponse:
1049
+ request = {
1050
+ "wallet_id": wallet_id,
1051
+ "nft_coin_id": nft_coin_id,
1052
+ "uri": uri,
1053
+ "key": key,
1054
+ "fee": fee,
1055
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1056
+ "push": push,
1057
+ **tx_config.to_json_dict(),
1058
+ **timelock_info.to_json_dict(),
1059
+ }
1060
+ response = await self.fetch("nft_add_uri", request)
1061
+ return json_deserialize_with_clvm_streamable(response, NFTAddURIResponse)
1062
+
1063
+ async def nft_calculate_royalties(
1064
+ self,
1065
+ royalty_assets_dict: dict[Any, tuple[Any, uint16]],
1066
+ fungible_asset_dict: dict[Any, uint64],
1067
+ ) -> dict[str, list[dict[str, Any]]]:
1068
+ request = {
1069
+ "royalty_assets": [
1070
+ {"asset": id, "royalty_address": royalty_info[0], "royalty_percentage": royalty_info[1]}
1071
+ for id, royalty_info in royalty_assets_dict.items()
1072
+ ],
1073
+ "fungible_assets": [{"asset": name, "amount": amount} for name, amount in fungible_asset_dict.items()],
1074
+ }
1075
+ response = await self.fetch("nft_calculate_royalties", request)
1076
+ del response["success"]
1077
+ return response
1078
+
1079
+ async def get_nft_info(self, coin_id: str, latest: bool = True) -> dict[str, Any]:
1080
+ request = {"coin_id": coin_id, "latest": latest}
1081
+ response = await self.fetch("nft_get_info", request)
1082
+ return response
1083
+
1084
+ async def transfer_nft(
1085
+ self,
1086
+ wallet_id: int,
1087
+ nft_coin_id: str,
1088
+ target_address: str,
1089
+ fee: int,
1090
+ tx_config: TXConfig,
1091
+ extra_conditions: tuple[Condition, ...] = tuple(),
1092
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1093
+ push: bool = True,
1094
+ ) -> NFTTransferNFTResponse:
1095
+ request = {
1096
+ "wallet_id": wallet_id,
1097
+ "nft_coin_id": nft_coin_id,
1098
+ "target_address": target_address,
1099
+ "fee": fee,
1100
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1101
+ "push": push,
1102
+ **tx_config.to_json_dict(),
1103
+ **timelock_info.to_json_dict(),
1104
+ }
1105
+ response = await self.fetch("nft_transfer_nft", request)
1106
+ return json_deserialize_with_clvm_streamable(response, NFTTransferNFTResponse)
1107
+
1108
+ async def count_nfts(self, wallet_id: Optional[int]) -> dict[str, Any]:
1109
+ request = {"wallet_id": wallet_id}
1110
+ response = await self.fetch("nft_count_nfts", request)
1111
+ return response
1112
+
1113
+ async def list_nfts(self, wallet_id: int, num: int = 50, start_index: int = 0) -> dict[str, Any]:
1114
+ request = {"wallet_id": wallet_id, "num": num, "start_index": start_index}
1115
+ response = await self.fetch("nft_get_nfts", request)
1116
+ return response
1117
+
1118
+ async def get_nft_wallet_by_did(self, request: NFTGetByDID) -> NFTGetByDIDResponse:
1119
+ return NFTGetByDIDResponse.from_json_dict(await self.fetch("nft_get_by_did", request.to_json_dict()))
1120
+
1121
+ async def set_nft_did(
1122
+ self,
1123
+ wallet_id: int,
1124
+ did_id: Optional[str],
1125
+ nft_coin_id: str,
1126
+ fee: int,
1127
+ tx_config: TXConfig,
1128
+ extra_conditions: tuple[Condition, ...] = tuple(),
1129
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1130
+ push: bool = True,
1131
+ ) -> NFTSetNFTDIDResponse:
1132
+ request = {
1133
+ "wallet_id": wallet_id,
1134
+ "nft_coin_id": nft_coin_id,
1135
+ "fee": fee,
1136
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1137
+ "push": push,
1138
+ **tx_config.to_json_dict(),
1139
+ **timelock_info.to_json_dict(),
1140
+ }
1141
+ if did_id is not None:
1142
+ request["did_id"] = did_id
1143
+ response = await self.fetch("nft_set_nft_did", request)
1144
+ return json_deserialize_with_clvm_streamable(response, NFTSetNFTDIDResponse)
1145
+
1146
+ async def set_nft_status(self, request: NFTSetNFTStatus) -> None:
1147
+ await self.fetch("nft_set_nft_status", request.to_json_dict())
1148
+
1149
+ async def get_nft_wallet_did(self, wallet_id: int) -> dict[str, Any]:
1150
+ request = {"wallet_id": wallet_id}
1151
+ response = await self.fetch("nft_get_wallet_did", request)
1152
+ return response
1153
+
1154
+ async def get_nft_wallets_with_dids(self) -> NFTGetWalletsWithDIDsResponse:
1155
+ return NFTGetWalletsWithDIDsResponse.from_json_dict(await self.fetch("nft_get_wallets_with_dids", {}))
1156
+
1157
+ async def nft_mint_bulk(
1158
+ self,
1159
+ wallet_id: int,
1160
+ metadata_list: list[dict[str, Any]],
1161
+ royalty_percentage: Optional[int],
1162
+ royalty_address: Optional[str],
1163
+ tx_config: TXConfig,
1164
+ target_list: Optional[list[str]] = None,
1165
+ mint_number_start: Optional[int] = 1,
1166
+ mint_total: Optional[int] = None,
1167
+ xch_coins: Optional[list[dict[str, Any]]] = None,
1168
+ xch_change_target: Optional[str] = None,
1169
+ new_innerpuzhash: Optional[str] = None,
1170
+ did_coin: Optional[dict[str, Any]] = None,
1171
+ did_lineage_parent: Optional[str] = None,
1172
+ mint_from_did: Optional[bool] = False,
1173
+ fee: Optional[int] = 0,
1174
+ extra_conditions: tuple[Condition, ...] = tuple(),
1175
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1176
+ push: bool = False,
1177
+ ) -> NFTMintBulkResponse:
1178
+ request = {
1179
+ "wallet_id": wallet_id,
1180
+ "metadata_list": metadata_list,
1181
+ "target_list": target_list,
1182
+ "royalty_percentage": royalty_percentage,
1183
+ "royalty_address": royalty_address,
1184
+ "mint_number_start": mint_number_start,
1185
+ "mint_total": mint_total,
1186
+ "xch_coins": xch_coins,
1187
+ "xch_change_target": xch_change_target,
1188
+ "new_innerpuzhash": new_innerpuzhash,
1189
+ "did_coin": did_coin,
1190
+ "did_lineage_parent": did_lineage_parent,
1191
+ "mint_from_did": mint_from_did,
1192
+ "fee": fee,
1193
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1194
+ "push": push,
1195
+ **tx_config.to_json_dict(),
1196
+ **timelock_info.to_json_dict(),
1197
+ }
1198
+ response = await self.fetch("nft_mint_bulk", request)
1199
+ return json_deserialize_with_clvm_streamable(response, NFTMintBulkResponse)
1200
+
1201
+ async def set_nft_did_bulk(
1202
+ self,
1203
+ request: NFTSetDIDBulk,
1204
+ tx_config: TXConfig,
1205
+ extra_conditions: tuple[Condition, ...] = tuple(),
1206
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1207
+ ) -> NFTSetDIDBulkResponse:
1208
+ return NFTSetDIDBulkResponse.from_json_dict(
1209
+ await self.fetch(
1210
+ "nft_set_did_bulk", request.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1211
+ )
1212
+ )
1213
+
1214
+ async def transfer_nft_bulk(
1215
+ self,
1216
+ request: NFTTransferBulk,
1217
+ tx_config: TXConfig,
1218
+ extra_conditions: tuple[Condition, ...] = tuple(),
1219
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1220
+ ) -> NFTTransferBulkResponse:
1221
+ return NFTTransferBulkResponse.from_json_dict(
1222
+ await self.fetch(
1223
+ "nft_transfer_bulk", request.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1224
+ )
1225
+ )
1226
+
1227
+ # DataLayer
1228
+ async def create_new_dl(
1229
+ self,
1230
+ root: bytes32,
1231
+ fee: uint64,
1232
+ extra_conditions: tuple[Condition, ...] = tuple(),
1233
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1234
+ ) -> tuple[list[TransactionRecord], bytes32]:
1235
+ request = {
1236
+ "root": root.hex(),
1237
+ "fee": fee,
1238
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1239
+ **timelock_info.to_json_dict(),
1240
+ }
1241
+ response = await self.fetch("create_new_dl", request)
1242
+ txs = [TransactionRecord.from_json_dict_convenience(tx) for tx in response["transactions"]]
1243
+ launcher_id = bytes32.from_hexstr(response["launcher_id"])
1244
+ return txs, launcher_id
1245
+
1246
+ async def dl_track_new(self, launcher_id: bytes32) -> None:
1247
+ request = {"launcher_id": launcher_id.hex()}
1248
+ await self.fetch("dl_track_new", request)
1249
+
1250
+ async def dl_stop_tracking(self, launcher_id: bytes32) -> None:
1251
+ request = {"launcher_id": launcher_id.hex()}
1252
+ await self.fetch("dl_stop_tracking", request)
1253
+
1254
+ async def dl_latest_singleton(
1255
+ self, launcher_id: bytes32, only_confirmed: bool = False
1256
+ ) -> Optional[SingletonRecord]:
1257
+ request = {"launcher_id": launcher_id.hex(), "only_confirmed": only_confirmed}
1258
+ response = await self.fetch("dl_latest_singleton", request)
1259
+ return None if response["singleton"] is None else SingletonRecord.from_json_dict(response["singleton"])
1260
+
1261
+ async def dl_singletons_by_root(self, launcher_id: bytes32, root: bytes32) -> list[SingletonRecord]:
1262
+ request = {"launcher_id": launcher_id.hex(), "root": root.hex()}
1263
+ response = await self.fetch("dl_singletons_by_root", request)
1264
+ return [SingletonRecord.from_json_dict(single) for single in response["singletons"]]
1265
+
1266
+ async def dl_update_root(
1267
+ self,
1268
+ launcher_id: bytes32,
1269
+ new_root: bytes32,
1270
+ fee: uint64,
1271
+ extra_conditions: tuple[Condition, ...] = tuple(),
1272
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1273
+ ) -> TransactionRecord:
1274
+ request = {
1275
+ "launcher_id": launcher_id.hex(),
1276
+ "new_root": new_root.hex(),
1277
+ "fee": fee,
1278
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1279
+ **timelock_info.to_json_dict(),
1280
+ }
1281
+ response = await self.fetch("dl_update_root", request)
1282
+ return TransactionRecord.from_json_dict_convenience(response["tx_record"])
1283
+
1284
+ async def dl_update_multiple(
1285
+ self,
1286
+ update_dictionary: dict[bytes32, bytes32],
1287
+ fee: uint64,
1288
+ extra_conditions: tuple[Condition, ...] = tuple(),
1289
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1290
+ ) -> list[TransactionRecord]:
1291
+ updates_as_strings = {str(lid): str(root) for lid, root in update_dictionary.items()}
1292
+ request = {
1293
+ "updates": updates_as_strings,
1294
+ "fee": fee,
1295
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1296
+ **timelock_info.to_json_dict(),
1297
+ }
1298
+ response = await self.fetch("dl_update_multiple", request)
1299
+ return [TransactionRecord.from_json_dict_convenience(tx) for tx in response["transactions"]]
1300
+
1301
+ async def dl_history(
1302
+ self,
1303
+ launcher_id: bytes32,
1304
+ min_generation: Optional[uint32] = None,
1305
+ max_generation: Optional[uint32] = None,
1306
+ num_results: Optional[uint32] = None,
1307
+ ) -> list[SingletonRecord]:
1308
+ request = {"launcher_id": launcher_id.hex()}
1309
+
1310
+ if min_generation is not None:
1311
+ request["min_generation"] = str(min_generation)
1312
+ if max_generation is not None:
1313
+ request["max_generation"] = str(max_generation)
1314
+ if num_results is not None:
1315
+ request["num_results"] = str(num_results)
1316
+
1317
+ response = await self.fetch("dl_history", request)
1318
+ return [SingletonRecord.from_json_dict(single) for single in response["history"]]
1319
+
1320
+ async def dl_owned_singletons(self) -> list[SingletonRecord]:
1321
+ response = await self.fetch(path="dl_owned_singletons", request_json={})
1322
+ return [SingletonRecord.from_json_dict(singleton) for singleton in response["singletons"]]
1323
+
1324
+ async def dl_get_mirrors(self, launcher_id: bytes32) -> list[Mirror]:
1325
+ response = await self.fetch(path="dl_get_mirrors", request_json={"launcher_id": launcher_id.hex()})
1326
+ return [Mirror.from_json_dict(mirror) for mirror in response["mirrors"]]
1327
+
1328
+ async def dl_new_mirror(
1329
+ self,
1330
+ launcher_id: bytes32,
1331
+ amount: uint64,
1332
+ urls: list[bytes],
1333
+ fee: uint64 = uint64(0),
1334
+ extra_conditions: tuple[Condition, ...] = tuple(),
1335
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1336
+ ) -> list[TransactionRecord]:
1337
+ response = await self.fetch(
1338
+ path="dl_new_mirror",
1339
+ request_json={
1340
+ "launcher_id": launcher_id.hex(),
1341
+ "amount": amount,
1342
+ "urls": [url.decode("utf8") for url in urls],
1343
+ "fee": fee,
1344
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1345
+ **timelock_info.to_json_dict(),
1346
+ },
1347
+ )
1348
+ return [TransactionRecord.from_json_dict_convenience(tx) for tx in response["transactions"]]
1349
+
1350
+ async def dl_delete_mirror(
1351
+ self,
1352
+ coin_id: bytes32,
1353
+ fee: uint64 = uint64(0),
1354
+ extra_conditions: tuple[Condition, ...] = tuple(),
1355
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1356
+ ) -> list[TransactionRecord]:
1357
+ response = await self.fetch(
1358
+ path="dl_delete_mirror",
1359
+ request_json={
1360
+ "coin_id": coin_id.hex(),
1361
+ "fee": fee,
1362
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1363
+ **timelock_info.to_json_dict(),
1364
+ },
1365
+ )
1366
+ return [TransactionRecord.from_json_dict_convenience(tx) for tx in response["transactions"]]
1367
+
1368
+ async def dl_verify_proof(self, request: DLProof) -> VerifyProofResponse:
1369
+ response = await self.fetch(path="dl_verify_proof", request_json=request.to_json_dict())
1370
+ return json_deserialize_with_clvm_streamable(response, VerifyProofResponse)
1371
+
1372
+ async def get_notifications(self, request: GetNotifications) -> GetNotificationsResponse:
1373
+ response = await self.fetch("get_notifications", request.to_json_dict())
1374
+ return json_deserialize_with_clvm_streamable(response, GetNotificationsResponse)
1375
+
1376
+ async def delete_notifications(self, ids: Optional[Sequence[bytes32]] = None) -> bool:
1377
+ request = {}
1378
+ if ids is not None:
1379
+ request["ids"] = [id.hex() for id in ids]
1380
+ response = await self.fetch("delete_notifications", request)
1381
+ # TODO: casting due to lack of type checked deserialization
1382
+ result = cast(bool, response["success"])
1383
+ return result
1384
+
1385
+ async def send_notification(
1386
+ self,
1387
+ target: bytes32,
1388
+ msg: bytes,
1389
+ amount: uint64,
1390
+ fee: uint64 = uint64(0),
1391
+ extra_conditions: tuple[Condition, ...] = tuple(),
1392
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1393
+ push: bool = True,
1394
+ ) -> TransactionRecord:
1395
+ response = await self.fetch(
1396
+ "send_notification",
1397
+ {
1398
+ "target": target.hex(),
1399
+ "message": msg.hex(),
1400
+ "amount": amount,
1401
+ "fee": fee,
1402
+ "extra_conditions": conditions_to_json_dicts(extra_conditions),
1403
+ "push": push,
1404
+ **timelock_info.to_json_dict(),
1405
+ },
1406
+ )
1407
+ return TransactionRecord.from_json_dict_convenience(response["tx"])
1408
+
1409
+ async def sign_message_by_address(self, address: str, message: str) -> tuple[str, str, str]:
1410
+ response = await self.fetch("sign_message_by_address", {"address": address, "message": message})
1411
+ return response["pubkey"], response["signature"], response["signing_mode"]
1412
+
1413
+ async def sign_message_by_id(
1414
+ self, id: str, message: str, is_hex: bool = False, safe_mode: bool = True
1415
+ ) -> tuple[str, str, str]:
1416
+ response = await self.fetch(
1417
+ "sign_message_by_id", {"id": id, "message": message, "is_hex": is_hex, "safe_mode": safe_mode}
1418
+ )
1419
+ return response["pubkey"], response["signature"], response["signing_mode"]
1420
+
1421
+ async def verify_signature(self, request: VerifySignature) -> VerifySignatureResponse:
1422
+ return VerifySignatureResponse.from_json_dict(await self.fetch("verify_signature", {**request.to_json_dict()}))
1423
+
1424
+ async def get_transaction_memo(self, request: GetTransactionMemo) -> GetTransactionMemoResponse:
1425
+ return GetTransactionMemoResponse.from_json_dict(
1426
+ await self.fetch("get_transaction_memo", {**request.to_json_dict()})
1427
+ )
1428
+
1429
+ # DAOs
1430
+ async def create_new_dao_wallet(
1431
+ self,
1432
+ mode: str,
1433
+ tx_config: TXConfig,
1434
+ dao_rules: Optional[dict[str, uint64]] = None,
1435
+ amount_of_cats: Optional[uint64] = None,
1436
+ treasury_id: Optional[bytes32] = None,
1437
+ filter_amount: uint64 = uint64(1),
1438
+ name: Optional[str] = None,
1439
+ fee: uint64 = uint64(0),
1440
+ fee_for_cat: uint64 = uint64(0),
1441
+ extra_conditions: tuple[Condition, ...] = tuple(),
1442
+ push: bool = True,
1443
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1444
+ ) -> CreateNewDAOWalletResponse:
1445
+ request: dict[str, Any] = {
1446
+ "wallet_type": "dao_wallet",
1447
+ "mode": mode,
1448
+ "treasury_id": treasury_id.hex() if treasury_id is not None else treasury_id,
1449
+ "dao_rules": dao_rules,
1450
+ "amount_of_cats": amount_of_cats,
1451
+ "filter_amount": filter_amount,
1452
+ "name": name,
1453
+ "fee": fee,
1454
+ "fee_for_cat": fee_for_cat,
1455
+ "extra_conditions": list(extra_conditions),
1456
+ "push": push,
1457
+ **tx_config.to_json_dict(),
1458
+ **timelock_info.to_json_dict(),
1459
+ }
1460
+ response = await self.fetch("create_new_wallet", request)
1461
+ return json_deserialize_with_clvm_streamable(response, CreateNewDAOWalletResponse)
1462
+
1463
+ async def dao_get_treasury_id(self, wallet_id: int) -> dict[str, Any]:
1464
+ request = {"wallet_id": wallet_id}
1465
+ response = await self.fetch("dao_get_treasury_id", request)
1466
+ return response
1467
+
1468
+ async def dao_get_rules(self, wallet_id: int) -> dict[str, Any]:
1469
+ request = {"wallet_id": wallet_id}
1470
+ response = await self.fetch("dao_get_rules", request)
1471
+ return response
1472
+
1473
+ async def dao_create_proposal(
1474
+ self,
1475
+ wallet_id: int,
1476
+ proposal_type: str,
1477
+ tx_config: TXConfig,
1478
+ additions: Optional[list[dict[str, Any]]] = None,
1479
+ amount: Optional[uint64] = None,
1480
+ inner_address: Optional[str] = None,
1481
+ asset_id: Optional[str] = None,
1482
+ cat_target_address: Optional[str] = None,
1483
+ vote_amount: Optional[int] = None,
1484
+ new_dao_rules: Optional[dict[str, Optional[uint64]]] = None,
1485
+ fee: uint64 = uint64(0),
1486
+ extra_conditions: tuple[Condition, ...] = tuple(),
1487
+ push: bool = True,
1488
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1489
+ ) -> DAOCreateProposalResponse:
1490
+ request: dict[str, Any] = {
1491
+ "wallet_id": wallet_id,
1492
+ "proposal_type": proposal_type,
1493
+ "additions": additions,
1494
+ "amount": amount,
1495
+ "inner_address": inner_address,
1496
+ "asset_id": asset_id,
1497
+ "cat_target_address": cat_target_address,
1498
+ "vote_amount": vote_amount,
1499
+ "new_dao_rules": new_dao_rules,
1500
+ "fee": fee,
1501
+ "extra_conditions": list(extra_conditions),
1502
+ **tx_config.to_json_dict(),
1503
+ **timelock_info.to_json_dict(),
1504
+ }
1505
+
1506
+ response = await self.fetch("dao_create_proposal", request)
1507
+ return json_deserialize_with_clvm_streamable(response, DAOCreateProposalResponse)
1508
+
1509
+ async def dao_get_proposal_state(self, wallet_id: int, proposal_id: str) -> dict[str, Any]:
1510
+ request = {"wallet_id": wallet_id, "proposal_id": proposal_id}
1511
+ response = await self.fetch("dao_get_proposal_state", request)
1512
+ return response
1513
+
1514
+ async def dao_parse_proposal(self, wallet_id: int, proposal_id: str) -> dict[str, Any]:
1515
+ request = {"wallet_id": wallet_id, "proposal_id": proposal_id}
1516
+ response = await self.fetch("dao_parse_proposal", request)
1517
+ return response
1518
+
1519
+ async def dao_vote_on_proposal(
1520
+ self,
1521
+ wallet_id: int,
1522
+ proposal_id: str,
1523
+ vote_amount: uint64,
1524
+ tx_config: TXConfig,
1525
+ is_yes_vote: bool = True,
1526
+ fee: uint64 = uint64(0),
1527
+ extra_conditions: tuple[Condition, ...] = tuple(),
1528
+ push: bool = True,
1529
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1530
+ ) -> DAOVoteOnProposalResponse:
1531
+ request: dict[str, Any] = {
1532
+ "wallet_id": wallet_id,
1533
+ "proposal_id": proposal_id,
1534
+ "vote_amount": vote_amount,
1535
+ "is_yes_vote": is_yes_vote,
1536
+ "fee": fee,
1537
+ "extra_conditions": list(extra_conditions),
1538
+ "push": push,
1539
+ **tx_config.to_json_dict(),
1540
+ **timelock_info.to_json_dict(),
1541
+ }
1542
+ response = await self.fetch("dao_vote_on_proposal", request)
1543
+ return json_deserialize_with_clvm_streamable(response, DAOVoteOnProposalResponse)
1544
+
1545
+ async def dao_get_proposals(self, wallet_id: int, include_closed: bool = True) -> dict[str, Any]:
1546
+ request = {"wallet_id": wallet_id, "include_closed": include_closed}
1547
+ response = await self.fetch("dao_get_proposals", request)
1548
+ return response
1549
+
1550
+ async def dao_close_proposal(
1551
+ self,
1552
+ wallet_id: int,
1553
+ proposal_id: str,
1554
+ tx_config: TXConfig,
1555
+ self_destruct: Optional[bool] = None,
1556
+ fee: uint64 = uint64(0),
1557
+ extra_conditions: tuple[Condition, ...] = tuple(),
1558
+ push: bool = True,
1559
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1560
+ ) -> DAOCloseProposalResponse:
1561
+ request: dict[str, Any] = {
1562
+ "wallet_id": wallet_id,
1563
+ "proposal_id": proposal_id,
1564
+ "self_destruct": self_destruct,
1565
+ "fee": fee,
1566
+ "extra_conditions": list(extra_conditions),
1567
+ "push": push,
1568
+ **tx_config.to_json_dict(),
1569
+ **timelock_info.to_json_dict(),
1570
+ }
1571
+ response = await self.fetch("dao_close_proposal", request)
1572
+ return json_deserialize_with_clvm_streamable(response, DAOCloseProposalResponse)
1573
+
1574
+ async def dao_free_coins_from_finished_proposals(
1575
+ self,
1576
+ wallet_id: int,
1577
+ tx_config: TXConfig,
1578
+ fee: uint64 = uint64(0),
1579
+ extra_conditions: tuple[Condition, ...] = tuple(),
1580
+ push: bool = True,
1581
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1582
+ ) -> DAOFreeCoinsFromFinishedProposalsResponse:
1583
+ request: dict[str, Any] = {
1584
+ "wallet_id": wallet_id,
1585
+ "fee": fee,
1586
+ "extra_conditions": list(extra_conditions),
1587
+ **tx_config.to_json_dict(),
1588
+ **timelock_info.to_json_dict(),
1589
+ }
1590
+ response = await self.fetch("dao_free_coins_from_finished_proposals", request)
1591
+ return json_deserialize_with_clvm_streamable(response, DAOFreeCoinsFromFinishedProposalsResponse)
1592
+
1593
+ async def dao_get_treasury_balance(self, wallet_id: int) -> dict[str, Any]:
1594
+ request = {"wallet_id": wallet_id}
1595
+ response = await self.fetch("dao_get_treasury_balance", request)
1596
+ return response
1597
+
1598
+ async def dao_add_funds_to_treasury(
1599
+ self,
1600
+ wallet_id: int,
1601
+ funding_wallet_id: int,
1602
+ amount: uint64,
1603
+ tx_config: TXConfig,
1604
+ fee: uint64 = uint64(0),
1605
+ extra_conditions: tuple[Condition, ...] = tuple(),
1606
+ push: bool = True,
1607
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1608
+ ) -> DAOAddFundsToTreasuryResponse:
1609
+ request: dict[str, Any] = {
1610
+ "wallet_id": wallet_id,
1611
+ "funding_wallet_id": funding_wallet_id,
1612
+ "amount": amount,
1613
+ "fee": fee,
1614
+ "extra_conditions": list(extra_conditions),
1615
+ "push": push,
1616
+ **tx_config.to_json_dict(),
1617
+ **timelock_info.to_json_dict(),
1618
+ }
1619
+ response = await self.fetch("dao_add_funds_to_treasury", request)
1620
+ return json_deserialize_with_clvm_streamable(response, DAOAddFundsToTreasuryResponse)
1621
+
1622
+ async def dao_send_to_lockup(
1623
+ self,
1624
+ wallet_id: int,
1625
+ amount: uint64,
1626
+ tx_config: TXConfig,
1627
+ fee: uint64 = uint64(0),
1628
+ extra_conditions: tuple[Condition, ...] = tuple(),
1629
+ push: bool = True,
1630
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1631
+ ) -> DAOSendToLockupResponse:
1632
+ request: dict[str, Any] = {
1633
+ "wallet_id": wallet_id,
1634
+ "amount": amount,
1635
+ "fee": fee,
1636
+ "extra_conditions": list(extra_conditions),
1637
+ "push": push,
1638
+ **tx_config.to_json_dict(),
1639
+ **timelock_info.to_json_dict(),
1640
+ }
1641
+ response = await self.fetch("dao_send_to_lockup", request)
1642
+ return json_deserialize_with_clvm_streamable(response, DAOSendToLockupResponse)
1643
+
1644
+ async def dao_exit_lockup(
1645
+ self,
1646
+ wallet_id: int,
1647
+ tx_config: TXConfig,
1648
+ coins: Optional[list[dict[str, Any]]] = None,
1649
+ fee: uint64 = uint64(0),
1650
+ extra_conditions: tuple[Condition, ...] = tuple(),
1651
+ push: bool = True,
1652
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1653
+ ) -> DAOExitLockupResponse:
1654
+ request: dict[str, Any] = {
1655
+ "wallet_id": wallet_id,
1656
+ "coins": coins,
1657
+ "fee": fee,
1658
+ "extra_conditions": list(extra_conditions),
1659
+ "push": push,
1660
+ **tx_config.to_json_dict(),
1661
+ **timelock_info.to_json_dict(),
1662
+ }
1663
+ response = await self.fetch("dao_exit_lockup", request)
1664
+ return json_deserialize_with_clvm_streamable(response, DAOExitLockupResponse)
1665
+
1666
+ async def dao_adjust_filter_level(self, wallet_id: int, filter_level: int) -> dict[str, Any]:
1667
+ request = {"wallet_id": wallet_id, "filter_level": filter_level}
1668
+ response = await self.fetch("dao_adjust_filter_level", request)
1669
+ return response
1670
+
1671
+ async def vc_mint(
1672
+ self,
1673
+ request: VCMint,
1674
+ tx_config: TXConfig,
1675
+ extra_conditions: tuple[Condition, ...] = tuple(),
1676
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1677
+ ) -> VCMintResponse:
1678
+ return VCMintResponse.from_json_dict(
1679
+ await self.fetch(
1680
+ "vc_mint", request.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1681
+ )
1682
+ )
1683
+
1684
+ async def vc_get(self, request: VCGet) -> VCGetResponse:
1685
+ return VCGetResponse.from_json_dict(await self.fetch("vc_get", request.to_json_dict()))
1686
+
1687
+ async def vc_get_list(self, request: VCGetList) -> VCGetListResponse:
1688
+ return VCGetListResponse.from_json_dict(await self.fetch("vc_get_list", request.to_json_dict()))
1689
+
1690
+ async def vc_spend(
1691
+ self,
1692
+ request: VCSpend,
1693
+ tx_config: TXConfig,
1694
+ extra_conditions: tuple[Condition, ...] = tuple(),
1695
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1696
+ ) -> VCSpendResponse:
1697
+ return VCSpendResponse.from_json_dict(
1698
+ await self.fetch(
1699
+ "vc_spend", request.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1700
+ )
1701
+ )
1702
+
1703
+ async def vc_add_proofs(self, request: VCAddProofs) -> None:
1704
+ await self.fetch("vc_add_proofs", request.to_json_dict())
1705
+
1706
+ async def vc_get_proofs_for_root(self, request: VCGetProofsForRoot) -> VCGetProofsForRootResponse:
1707
+ return VCGetProofsForRootResponse.from_json_dict(
1708
+ await self.fetch("vc_get_proofs_for_root", request.to_json_dict())
1709
+ )
1710
+
1711
+ async def vc_revoke(
1712
+ self,
1713
+ request: VCRevoke,
1714
+ tx_config: TXConfig,
1715
+ extra_conditions: tuple[Condition, ...] = tuple(),
1716
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1717
+ ) -> VCRevokeResponse:
1718
+ return VCRevokeResponse.from_json_dict(
1719
+ await self.fetch(
1720
+ "vc_revoke", request.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1721
+ )
1722
+ )
1723
+
1724
+ async def crcat_approve_pending(
1725
+ self,
1726
+ wallet_id: uint32,
1727
+ min_amount_to_claim: uint64,
1728
+ tx_config: TXConfig,
1729
+ fee: uint64 = uint64(0),
1730
+ push: bool = True,
1731
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1732
+ ) -> list[TransactionRecord]:
1733
+ response = await self.fetch(
1734
+ "crcat_approve_pending",
1735
+ {
1736
+ "wallet_id": wallet_id,
1737
+ "min_amount_to_claim": min_amount_to_claim,
1738
+ "fee": fee,
1739
+ "push": push,
1740
+ **tx_config.to_json_dict(),
1741
+ **timelock_info.to_json_dict(),
1742
+ },
1743
+ )
1744
+ return [TransactionRecord.from_json_dict_convenience(tx) for tx in response["transactions"]]
1745
+
1746
+ async def gather_signing_info(
1747
+ self,
1748
+ args: GatherSigningInfo,
1749
+ ) -> GatherSigningInfoResponse:
1750
+ return json_deserialize_with_clvm_streamable(
1751
+ await self.fetch(
1752
+ "gather_signing_info",
1753
+ args.to_json_dict(),
1754
+ ),
1755
+ GatherSigningInfoResponse,
1756
+ )
1757
+
1758
+ async def apply_signatures(
1759
+ self,
1760
+ args: ApplySignatures,
1761
+ ) -> ApplySignaturesResponse:
1762
+ return json_deserialize_with_clvm_streamable(
1763
+ await self.fetch(
1764
+ "apply_signatures",
1765
+ args.to_json_dict(),
1766
+ ),
1767
+ ApplySignaturesResponse,
1768
+ )
1769
+
1770
+ async def submit_transactions(
1771
+ self,
1772
+ args: SubmitTransactions,
1773
+ ) -> SubmitTransactionsResponse:
1774
+ return json_deserialize_with_clvm_streamable(
1775
+ await self.fetch(
1776
+ "submit_transactions",
1777
+ args.to_json_dict(),
1778
+ ),
1779
+ SubmitTransactionsResponse,
1780
+ )
1781
+
1782
+ async def execute_signing_instructions(
1783
+ self,
1784
+ args: ExecuteSigningInstructions,
1785
+ ) -> ExecuteSigningInstructionsResponse:
1786
+ return ExecuteSigningInstructionsResponse.from_json_dict(
1787
+ await self.fetch("execute_signing_instructions", args.to_json_dict())
1788
+ )
1789
+
1790
+ async def split_coins(
1791
+ self,
1792
+ args: SplitCoins,
1793
+ tx_config: TXConfig,
1794
+ extra_conditions: tuple[Condition, ...] = tuple(),
1795
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1796
+ ) -> SplitCoinsResponse:
1797
+ return SplitCoinsResponse.from_json_dict(
1798
+ await self.fetch(
1799
+ "split_coins", args.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1800
+ )
1801
+ )
1802
+
1803
+ async def combine_coins(
1804
+ self,
1805
+ args: CombineCoins,
1806
+ tx_config: TXConfig,
1807
+ extra_conditions: tuple[Condition, ...] = tuple(),
1808
+ timelock_info: ConditionValidTimes = ConditionValidTimes(),
1809
+ ) -> CombineCoinsResponse:
1810
+ return CombineCoinsResponse.from_json_dict(
1811
+ await self.fetch(
1812
+ "combine_coins", args.json_serialize_for_transport(tx_config, extra_conditions, timelock_info)
1813
+ )
1814
+ )