chia-blockchain 2.4.4__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 (1028) 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 +197 -0
  7. chia/_tests/blockchain/config.py +4 -0
  8. chia/_tests/blockchain/test_augmented_chain.py +147 -0
  9. chia/_tests/blockchain/test_blockchain.py +4100 -0
  10. chia/_tests/blockchain/test_blockchain_transactions.py +1050 -0
  11. chia/_tests/blockchain/test_build_chains.py +61 -0
  12. chia/_tests/blockchain/test_get_block_generator.py +72 -0
  13. chia/_tests/blockchain/test_lookup_fork_chain.py +195 -0
  14. chia/_tests/build-init-files.py +93 -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 +73 -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 +147 -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 +57 -0
  26. chia/_tests/clvm/test_program.py +150 -0
  27. chia/_tests/clvm/test_puzzle_compression.py +144 -0
  28. chia/_tests/clvm/test_puzzle_drivers.py +45 -0
  29. chia/_tests/clvm/test_puzzles.py +247 -0
  30. chia/_tests/clvm/test_singletons.py +540 -0
  31. chia/_tests/clvm/test_spend_sim.py +181 -0
  32. chia/_tests/cmds/__init__.py +0 -0
  33. chia/_tests/cmds/cmd_test_utils.py +472 -0
  34. chia/_tests/cmds/config.py +3 -0
  35. chia/_tests/cmds/conftest.py +23 -0
  36. chia/_tests/cmds/test_click_types.py +195 -0
  37. chia/_tests/cmds/test_cmd_framework.py +400 -0
  38. chia/_tests/cmds/test_cmds_util.py +97 -0
  39. chia/_tests/cmds/test_daemon.py +92 -0
  40. chia/_tests/cmds/test_farm_cmd.py +67 -0
  41. chia/_tests/cmds/test_show.py +116 -0
  42. chia/_tests/cmds/test_sim.py +207 -0
  43. chia/_tests/cmds/test_timelock_args.py +75 -0
  44. chia/_tests/cmds/test_tx_config_args.py +153 -0
  45. chia/_tests/cmds/testing_classes.py +59 -0
  46. chia/_tests/cmds/wallet/__init__.py +0 -0
  47. chia/_tests/cmds/wallet/test_coins.py +195 -0
  48. chia/_tests/cmds/wallet/test_consts.py +47 -0
  49. chia/_tests/cmds/wallet/test_dao.py +565 -0
  50. chia/_tests/cmds/wallet/test_did.py +403 -0
  51. chia/_tests/cmds/wallet/test_nft.py +470 -0
  52. chia/_tests/cmds/wallet/test_notifications.py +124 -0
  53. chia/_tests/cmds/wallet/test_offer.toffer +1 -0
  54. chia/_tests/cmds/wallet/test_tx_decorators.py +27 -0
  55. chia/_tests/cmds/wallet/test_vcs.py +376 -0
  56. chia/_tests/cmds/wallet/test_wallet.py +1126 -0
  57. chia/_tests/cmds/wallet/test_wallet_check.py +111 -0
  58. chia/_tests/conftest.py +1304 -0
  59. chia/_tests/connection_utils.py +124 -0
  60. chia/_tests/core/__init__.py +0 -0
  61. chia/_tests/core/cmds/__init__.py +0 -0
  62. chia/_tests/core/cmds/test_beta.py +382 -0
  63. chia/_tests/core/cmds/test_keys.py +1734 -0
  64. chia/_tests/core/cmds/test_wallet.py +126 -0
  65. chia/_tests/core/config.py +3 -0
  66. chia/_tests/core/consensus/__init__.py +0 -0
  67. chia/_tests/core/consensus/test_block_creation.py +56 -0
  68. chia/_tests/core/consensus/test_pot_iterations.py +117 -0
  69. chia/_tests/core/custom_types/__init__.py +0 -0
  70. chia/_tests/core/custom_types/test_coin.py +109 -0
  71. chia/_tests/core/custom_types/test_proof_of_space.py +144 -0
  72. chia/_tests/core/custom_types/test_spend_bundle.py +71 -0
  73. chia/_tests/core/daemon/__init__.py +0 -0
  74. chia/_tests/core/daemon/config.py +4 -0
  75. chia/_tests/core/daemon/test_daemon.py +2128 -0
  76. chia/_tests/core/daemon/test_daemon_register.py +109 -0
  77. chia/_tests/core/daemon/test_keychain_proxy.py +100 -0
  78. chia/_tests/core/data_layer/__init__.py +0 -0
  79. chia/_tests/core/data_layer/config.py +5 -0
  80. chia/_tests/core/data_layer/conftest.py +105 -0
  81. chia/_tests/core/data_layer/test_data_cli.py +57 -0
  82. chia/_tests/core/data_layer/test_data_layer.py +83 -0
  83. chia/_tests/core/data_layer/test_data_layer_util.py +219 -0
  84. chia/_tests/core/data_layer/test_data_rpc.py +3865 -0
  85. chia/_tests/core/data_layer/test_data_store.py +2423 -0
  86. chia/_tests/core/data_layer/test_data_store_schema.py +381 -0
  87. chia/_tests/core/data_layer/test_plugin.py +91 -0
  88. chia/_tests/core/data_layer/util.py +232 -0
  89. chia/_tests/core/farmer/__init__.py +0 -0
  90. chia/_tests/core/farmer/config.py +3 -0
  91. chia/_tests/core/farmer/test_farmer_api.py +101 -0
  92. chia/_tests/core/full_node/__init__.py +0 -0
  93. chia/_tests/core/full_node/config.py +4 -0
  94. chia/_tests/core/full_node/dos/__init__.py +0 -0
  95. chia/_tests/core/full_node/dos/config.py +3 -0
  96. chia/_tests/core/full_node/full_sync/__init__.py +0 -0
  97. chia/_tests/core/full_node/full_sync/config.py +4 -0
  98. chia/_tests/core/full_node/full_sync/test_full_sync.py +448 -0
  99. chia/_tests/core/full_node/ram_db.py +27 -0
  100. chia/_tests/core/full_node/stores/__init__.py +0 -0
  101. chia/_tests/core/full_node/stores/config.py +4 -0
  102. chia/_tests/core/full_node/stores/test_block_store.py +488 -0
  103. chia/_tests/core/full_node/stores/test_coin_store.py +888 -0
  104. chia/_tests/core/full_node/stores/test_full_node_store.py +1215 -0
  105. chia/_tests/core/full_node/stores/test_hint_store.py +230 -0
  106. chia/_tests/core/full_node/stores/test_sync_store.py +135 -0
  107. chia/_tests/core/full_node/test_address_manager.py +588 -0
  108. chia/_tests/core/full_node/test_block_height_map.py +556 -0
  109. chia/_tests/core/full_node/test_conditions.py +558 -0
  110. chia/_tests/core/full_node/test_full_node.py +2445 -0
  111. chia/_tests/core/full_node/test_generator_tools.py +82 -0
  112. chia/_tests/core/full_node/test_hint_management.py +104 -0
  113. chia/_tests/core/full_node/test_node_load.py +34 -0
  114. chia/_tests/core/full_node/test_performance.py +182 -0
  115. chia/_tests/core/full_node/test_subscriptions.py +492 -0
  116. chia/_tests/core/full_node/test_transactions.py +203 -0
  117. chia/_tests/core/full_node/test_tx_processing_queue.py +154 -0
  118. chia/_tests/core/large_block.py +2388 -0
  119. chia/_tests/core/make_block_generator.py +72 -0
  120. chia/_tests/core/mempool/__init__.py +0 -0
  121. chia/_tests/core/mempool/config.py +4 -0
  122. chia/_tests/core/mempool/test_mempool.py +3180 -0
  123. chia/_tests/core/mempool/test_mempool_fee_estimator.py +104 -0
  124. chia/_tests/core/mempool/test_mempool_fee_protocol.py +55 -0
  125. chia/_tests/core/mempool/test_mempool_item_queries.py +192 -0
  126. chia/_tests/core/mempool/test_mempool_manager.py +2054 -0
  127. chia/_tests/core/mempool/test_mempool_performance.py +65 -0
  128. chia/_tests/core/mempool/test_singleton_fast_forward.py +567 -0
  129. chia/_tests/core/node_height.py +28 -0
  130. chia/_tests/core/server/__init__.py +0 -0
  131. chia/_tests/core/server/config.py +3 -0
  132. chia/_tests/core/server/flood.py +82 -0
  133. chia/_tests/core/server/serve.py +132 -0
  134. chia/_tests/core/server/test_capabilities.py +68 -0
  135. chia/_tests/core/server/test_dos.py +320 -0
  136. chia/_tests/core/server/test_event_loop.py +109 -0
  137. chia/_tests/core/server/test_loop.py +290 -0
  138. chia/_tests/core/server/test_node_discovery.py +74 -0
  139. chia/_tests/core/server/test_rate_limits.py +370 -0
  140. chia/_tests/core/server/test_server.py +225 -0
  141. chia/_tests/core/server/test_upnp.py +8 -0
  142. chia/_tests/core/services/__init__.py +0 -0
  143. chia/_tests/core/services/config.py +3 -0
  144. chia/_tests/core/services/test_services.py +166 -0
  145. chia/_tests/core/ssl/__init__.py +0 -0
  146. chia/_tests/core/ssl/config.py +3 -0
  147. chia/_tests/core/ssl/test_ssl.py +198 -0
  148. chia/_tests/core/test_coins.py +33 -0
  149. chia/_tests/core/test_cost_calculation.py +314 -0
  150. chia/_tests/core/test_crawler.py +175 -0
  151. chia/_tests/core/test_crawler_rpc.py +53 -0
  152. chia/_tests/core/test_daemon_rpc.py +24 -0
  153. chia/_tests/core/test_db_conversion.py +129 -0
  154. chia/_tests/core/test_db_validation.py +161 -0
  155. chia/_tests/core/test_farmer_harvester_rpc.py +504 -0
  156. chia/_tests/core/test_filter.py +37 -0
  157. chia/_tests/core/test_full_node_rpc.py +794 -0
  158. chia/_tests/core/test_merkle_set.py +343 -0
  159. chia/_tests/core/test_program.py +49 -0
  160. chia/_tests/core/test_rpc_util.py +87 -0
  161. chia/_tests/core/test_seeder.py +308 -0
  162. chia/_tests/core/test_setproctitle.py +13 -0
  163. chia/_tests/core/util/__init__.py +0 -0
  164. chia/_tests/core/util/config.py +4 -0
  165. chia/_tests/core/util/test_block_cache.py +44 -0
  166. chia/_tests/core/util/test_cached_bls.py +57 -0
  167. chia/_tests/core/util/test_config.py +337 -0
  168. chia/_tests/core/util/test_file_keyring_synchronization.py +105 -0
  169. chia/_tests/core/util/test_files.py +391 -0
  170. chia/_tests/core/util/test_jsonify.py +146 -0
  171. chia/_tests/core/util/test_keychain.py +514 -0
  172. chia/_tests/core/util/test_keyring_wrapper.py +490 -0
  173. chia/_tests/core/util/test_lockfile.py +380 -0
  174. chia/_tests/core/util/test_log_exceptions.py +187 -0
  175. chia/_tests/core/util/test_lru_cache.py +56 -0
  176. chia/_tests/core/util/test_significant_bits.py +40 -0
  177. chia/_tests/core/util/test_streamable.py +883 -0
  178. chia/_tests/db/__init__.py +0 -0
  179. chia/_tests/db/test_db_wrapper.py +565 -0
  180. chia/_tests/environments/__init__.py +0 -0
  181. chia/_tests/environments/common.py +35 -0
  182. chia/_tests/environments/full_node.py +47 -0
  183. chia/_tests/environments/wallet.py +368 -0
  184. chia/_tests/ether.py +19 -0
  185. chia/_tests/farmer_harvester/__init__.py +0 -0
  186. chia/_tests/farmer_harvester/config.py +3 -0
  187. chia/_tests/farmer_harvester/test_farmer.py +1264 -0
  188. chia/_tests/farmer_harvester/test_farmer_harvester.py +292 -0
  189. chia/_tests/farmer_harvester/test_filter_prefix_bits.py +130 -0
  190. chia/_tests/farmer_harvester/test_third_party_harvesters.py +501 -0
  191. chia/_tests/farmer_harvester/test_third_party_harvesters_data.json +29 -0
  192. chia/_tests/fee_estimation/__init__.py +0 -0
  193. chia/_tests/fee_estimation/config.py +3 -0
  194. chia/_tests/fee_estimation/test_fee_estimation_integration.py +262 -0
  195. chia/_tests/fee_estimation/test_fee_estimation_rpc.py +287 -0
  196. chia/_tests/fee_estimation/test_fee_estimation_unit_tests.py +145 -0
  197. chia/_tests/fee_estimation/test_mempoolitem_height_added.py +146 -0
  198. chia/_tests/generator/__init__.py +0 -0
  199. chia/_tests/generator/puzzles/__init__.py +0 -0
  200. chia/_tests/generator/puzzles/test_generator_deserialize.clsp +3 -0
  201. chia/_tests/generator/puzzles/test_generator_deserialize.clsp.hex +1 -0
  202. chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp +19 -0
  203. chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp.hex +1 -0
  204. chia/_tests/generator/test_compression.py +218 -0
  205. chia/_tests/generator/test_generator_types.py +44 -0
  206. chia/_tests/generator/test_rom.py +182 -0
  207. chia/_tests/plot_sync/__init__.py +0 -0
  208. chia/_tests/plot_sync/config.py +3 -0
  209. chia/_tests/plot_sync/test_delta.py +102 -0
  210. chia/_tests/plot_sync/test_plot_sync.py +617 -0
  211. chia/_tests/plot_sync/test_receiver.py +451 -0
  212. chia/_tests/plot_sync/test_sender.py +116 -0
  213. chia/_tests/plot_sync/test_sync_simulated.py +450 -0
  214. chia/_tests/plot_sync/util.py +67 -0
  215. chia/_tests/plotting/__init__.py +0 -0
  216. chia/_tests/plotting/config.py +3 -0
  217. chia/_tests/plotting/test_plot_manager.py +738 -0
  218. chia/_tests/plotting/util.py +13 -0
  219. chia/_tests/pools/__init__.py +0 -0
  220. chia/_tests/pools/config.py +5 -0
  221. chia/_tests/pools/test_pool_cmdline.py +23 -0
  222. chia/_tests/pools/test_pool_config.py +44 -0
  223. chia/_tests/pools/test_pool_puzzles_lifecycle.py +398 -0
  224. chia/_tests/pools/test_pool_rpc.py +1010 -0
  225. chia/_tests/pools/test_pool_wallet.py +201 -0
  226. chia/_tests/pools/test_wallet_pool_store.py +161 -0
  227. chia/_tests/process_junit.py +349 -0
  228. chia/_tests/rpc/__init__.py +0 -0
  229. chia/_tests/rpc/test_rpc_client.py +81 -0
  230. chia/_tests/simulation/__init__.py +0 -0
  231. chia/_tests/simulation/config.py +6 -0
  232. chia/_tests/simulation/test_simulation.py +501 -0
  233. chia/_tests/simulation/test_simulator.py +234 -0
  234. chia/_tests/simulation/test_start_simulator.py +106 -0
  235. chia/_tests/testconfig.py +13 -0
  236. chia/_tests/timelord/__init__.py +0 -0
  237. chia/_tests/timelord/config.py +3 -0
  238. chia/_tests/timelord/test_new_peak.py +437 -0
  239. chia/_tests/timelord/test_timelord.py +11 -0
  240. chia/_tests/tools/1315537.json +170 -0
  241. chia/_tests/tools/1315544.json +160 -0
  242. chia/_tests/tools/1315630.json +150 -0
  243. chia/_tests/tools/300000.json +105 -0
  244. chia/_tests/tools/442734.json +140 -0
  245. chia/_tests/tools/466212.json +130 -0
  246. chia/_tests/tools/__init__.py +0 -0
  247. chia/_tests/tools/config.py +5 -0
  248. chia/_tests/tools/test-blockchain-db.sqlite +0 -0
  249. chia/_tests/tools/test_full_sync.py +30 -0
  250. chia/_tests/tools/test_legacy_keyring.py +82 -0
  251. chia/_tests/tools/test_run_block.py +129 -0
  252. chia/_tests/util/__init__.py +0 -0
  253. chia/_tests/util/benchmark_cost.py +170 -0
  254. chia/_tests/util/benchmarks.py +154 -0
  255. chia/_tests/util/bip39_test_vectors.json +148 -0
  256. chia/_tests/util/blockchain.py +133 -0
  257. chia/_tests/util/blockchain_mock.py +132 -0
  258. chia/_tests/util/build_network_protocol_files.py +302 -0
  259. chia/_tests/util/clvm_generator.bin +0 -0
  260. chia/_tests/util/config.py +3 -0
  261. chia/_tests/util/constants.py +20 -0
  262. chia/_tests/util/db_connection.py +36 -0
  263. chia/_tests/util/full_sync.py +245 -0
  264. chia/_tests/util/gen_ssl_certs.py +115 -0
  265. chia/_tests/util/generator_tools_testing.py +47 -0
  266. chia/_tests/util/key_tool.py +37 -0
  267. chia/_tests/util/misc.py +722 -0
  268. chia/_tests/util/network_protocol_data.py +1074 -0
  269. chia/_tests/util/protocol_messages_bytes-v1.0 +0 -0
  270. chia/_tests/util/protocol_messages_json.py +2700 -0
  271. chia/_tests/util/rpc.py +23 -0
  272. chia/_tests/util/run_block.py +163 -0
  273. chia/_tests/util/setup_nodes.py +479 -0
  274. chia/_tests/util/split_managers.py +99 -0
  275. chia/_tests/util/temp_file.py +14 -0
  276. chia/_tests/util/test_action_scope.py +143 -0
  277. chia/_tests/util/test_async_pool.py +366 -0
  278. chia/_tests/util/test_build_job_matrix.py +43 -0
  279. chia/_tests/util/test_build_network_protocol_files.py +7 -0
  280. chia/_tests/util/test_chia_version.py +50 -0
  281. chia/_tests/util/test_collection.py +11 -0
  282. chia/_tests/util/test_condition_tools.py +231 -0
  283. chia/_tests/util/test_config.py +426 -0
  284. chia/_tests/util/test_dump_keyring.py +60 -0
  285. chia/_tests/util/test_errors.py +10 -0
  286. chia/_tests/util/test_full_block_utils.py +271 -0
  287. chia/_tests/util/test_installed.py +20 -0
  288. chia/_tests/util/test_limited_semaphore.py +52 -0
  289. chia/_tests/util/test_logging_filter.py +43 -0
  290. chia/_tests/util/test_misc.py +444 -0
  291. chia/_tests/util/test_network.py +74 -0
  292. chia/_tests/util/test_network_protocol_files.py +579 -0
  293. chia/_tests/util/test_network_protocol_json.py +266 -0
  294. chia/_tests/util/test_network_protocol_test.py +257 -0
  295. chia/_tests/util/test_paginator.py +72 -0
  296. chia/_tests/util/test_pprint.py +17 -0
  297. chia/_tests/util/test_priority_mutex.py +487 -0
  298. chia/_tests/util/test_recursive_replace.py +116 -0
  299. chia/_tests/util/test_replace_str_to_bytes.py +137 -0
  300. chia/_tests/util/test_service_groups.py +15 -0
  301. chia/_tests/util/test_ssl_check.py +31 -0
  302. chia/_tests/util/test_testnet_overrides.py +19 -0
  303. chia/_tests/util/test_tests_misc.py +38 -0
  304. chia/_tests/util/test_timing.py +37 -0
  305. chia/_tests/util/test_trusted_peer.py +51 -0
  306. chia/_tests/util/time_out_assert.py +154 -0
  307. chia/_tests/wallet/__init__.py +0 -0
  308. chia/_tests/wallet/cat_wallet/__init__.py +0 -0
  309. chia/_tests/wallet/cat_wallet/config.py +4 -0
  310. chia/_tests/wallet/cat_wallet/test_cat_lifecycle.py +468 -0
  311. chia/_tests/wallet/cat_wallet/test_cat_outer_puzzle.py +69 -0
  312. chia/_tests/wallet/cat_wallet/test_cat_wallet.py +1738 -0
  313. chia/_tests/wallet/cat_wallet/test_offer_lifecycle.py +291 -0
  314. chia/_tests/wallet/cat_wallet/test_trades.py +2578 -0
  315. chia/_tests/wallet/clawback/__init__.py +0 -0
  316. chia/_tests/wallet/clawback/config.py +3 -0
  317. chia/_tests/wallet/clawback/test_clawback_decorator.py +80 -0
  318. chia/_tests/wallet/clawback/test_clawback_lifecycle.py +292 -0
  319. chia/_tests/wallet/clawback/test_clawback_metadata.py +51 -0
  320. chia/_tests/wallet/config.py +4 -0
  321. chia/_tests/wallet/conftest.py +217 -0
  322. chia/_tests/wallet/dao_wallet/__init__.py +0 -0
  323. chia/_tests/wallet/dao_wallet/config.py +3 -0
  324. chia/_tests/wallet/dao_wallet/test_dao_clvm.py +1322 -0
  325. chia/_tests/wallet/dao_wallet/test_dao_wallets.py +3488 -0
  326. chia/_tests/wallet/db_wallet/__init__.py +0 -0
  327. chia/_tests/wallet/db_wallet/config.py +3 -0
  328. chia/_tests/wallet/db_wallet/test_db_graftroot.py +143 -0
  329. chia/_tests/wallet/db_wallet/test_dl_offers.py +491 -0
  330. chia/_tests/wallet/db_wallet/test_dl_wallet.py +823 -0
  331. chia/_tests/wallet/did_wallet/__init__.py +0 -0
  332. chia/_tests/wallet/did_wallet/config.py +4 -0
  333. chia/_tests/wallet/did_wallet/test_did.py +1481 -0
  334. chia/_tests/wallet/nft_wallet/__init__.py +0 -0
  335. chia/_tests/wallet/nft_wallet/config.py +4 -0
  336. chia/_tests/wallet/nft_wallet/test_nft_1_offers.py +1492 -0
  337. chia/_tests/wallet/nft_wallet/test_nft_bulk_mint.py +1014 -0
  338. chia/_tests/wallet/nft_wallet/test_nft_lifecycle.py +376 -0
  339. chia/_tests/wallet/nft_wallet/test_nft_offers.py +1209 -0
  340. chia/_tests/wallet/nft_wallet/test_nft_puzzles.py +172 -0
  341. chia/_tests/wallet/nft_wallet/test_nft_wallet.py +2558 -0
  342. chia/_tests/wallet/nft_wallet/test_ownership_outer_puzzle.py +70 -0
  343. chia/_tests/wallet/rpc/__init__.py +0 -0
  344. chia/_tests/wallet/rpc/config.py +4 -0
  345. chia/_tests/wallet/rpc/test_dl_wallet_rpc.py +287 -0
  346. chia/_tests/wallet/rpc/test_wallet_rpc.py +3106 -0
  347. chia/_tests/wallet/simple_sync/__init__.py +0 -0
  348. chia/_tests/wallet/simple_sync/config.py +3 -0
  349. chia/_tests/wallet/simple_sync/test_simple_sync_protocol.py +719 -0
  350. chia/_tests/wallet/sync/__init__.py +0 -0
  351. chia/_tests/wallet/sync/config.py +4 -0
  352. chia/_tests/wallet/sync/test_wallet_sync.py +1529 -0
  353. chia/_tests/wallet/test_address_type.py +189 -0
  354. chia/_tests/wallet/test_bech32m.py +45 -0
  355. chia/_tests/wallet/test_clvm_streamable.py +244 -0
  356. chia/_tests/wallet/test_coin_selection.py +589 -0
  357. chia/_tests/wallet/test_conditions.py +388 -0
  358. chia/_tests/wallet/test_debug_spend_bundle.py +76 -0
  359. chia/_tests/wallet/test_new_wallet_protocol.py +1176 -0
  360. chia/_tests/wallet/test_nft_store.py +193 -0
  361. chia/_tests/wallet/test_notifications.py +196 -0
  362. chia/_tests/wallet/test_offer_parsing_performance.py +48 -0
  363. chia/_tests/wallet/test_puzzle_store.py +133 -0
  364. chia/_tests/wallet/test_sign_coin_spends.py +159 -0
  365. chia/_tests/wallet/test_signer_protocol.py +948 -0
  366. chia/_tests/wallet/test_singleton.py +122 -0
  367. chia/_tests/wallet/test_singleton_lifecycle_fast.py +772 -0
  368. chia/_tests/wallet/test_singleton_store.py +152 -0
  369. chia/_tests/wallet/test_taproot.py +19 -0
  370. chia/_tests/wallet/test_transaction_store.py +941 -0
  371. chia/_tests/wallet/test_util.py +181 -0
  372. chia/_tests/wallet/test_wallet.py +2139 -0
  373. chia/_tests/wallet/test_wallet_action_scope.py +85 -0
  374. chia/_tests/wallet/test_wallet_blockchain.py +113 -0
  375. chia/_tests/wallet/test_wallet_coin_store.py +1002 -0
  376. chia/_tests/wallet/test_wallet_interested_store.py +43 -0
  377. chia/_tests/wallet/test_wallet_key_val_store.py +40 -0
  378. chia/_tests/wallet/test_wallet_node.py +783 -0
  379. chia/_tests/wallet/test_wallet_retry.py +95 -0
  380. chia/_tests/wallet/test_wallet_state_manager.py +252 -0
  381. chia/_tests/wallet/test_wallet_test_framework.py +275 -0
  382. chia/_tests/wallet/test_wallet_trade_store.py +218 -0
  383. chia/_tests/wallet/test_wallet_user_store.py +34 -0
  384. chia/_tests/wallet/test_wallet_utils.py +155 -0
  385. chia/_tests/wallet/vc_wallet/__init__.py +0 -0
  386. chia/_tests/wallet/vc_wallet/config.py +3 -0
  387. chia/_tests/wallet/vc_wallet/test_cr_outer_puzzle.py +70 -0
  388. chia/_tests/wallet/vc_wallet/test_vc_lifecycle.py +883 -0
  389. chia/_tests/wallet/vc_wallet/test_vc_wallet.py +801 -0
  390. chia/_tests/wallet/wallet_block_tools.py +327 -0
  391. chia/_tests/weight_proof/__init__.py +0 -0
  392. chia/_tests/weight_proof/config.py +3 -0
  393. chia/_tests/weight_proof/test_weight_proof.py +528 -0
  394. chia/clvm/__init__.py +0 -0
  395. chia/clvm/spend_sim.py +488 -0
  396. chia/cmds/__init__.py +0 -0
  397. chia/cmds/beta.py +183 -0
  398. chia/cmds/beta_funcs.py +133 -0
  399. chia/cmds/check_wallet_db.py +418 -0
  400. chia/cmds/chia.py +143 -0
  401. chia/cmds/cmd_classes.py +315 -0
  402. chia/cmds/cmds_util.py +498 -0
  403. chia/cmds/coin_funcs.py +260 -0
  404. chia/cmds/coins.py +220 -0
  405. chia/cmds/completion.py +49 -0
  406. chia/cmds/configure.py +331 -0
  407. chia/cmds/dao.py +1008 -0
  408. chia/cmds/dao_funcs.py +576 -0
  409. chia/cmds/data.py +707 -0
  410. chia/cmds/data_funcs.py +380 -0
  411. chia/cmds/db.py +86 -0
  412. chia/cmds/db_backup_func.py +77 -0
  413. chia/cmds/db_upgrade_func.py +452 -0
  414. chia/cmds/db_validate_func.py +184 -0
  415. chia/cmds/dev.py +16 -0
  416. chia/cmds/farm.py +87 -0
  417. chia/cmds/farm_funcs.py +207 -0
  418. chia/cmds/init.py +70 -0
  419. chia/cmds/init_funcs.py +367 -0
  420. chia/cmds/installers.py +129 -0
  421. chia/cmds/keys.py +510 -0
  422. chia/cmds/keys_funcs.py +864 -0
  423. chia/cmds/netspace.py +47 -0
  424. chia/cmds/netspace_funcs.py +53 -0
  425. chia/cmds/options.py +32 -0
  426. chia/cmds/param_types.py +228 -0
  427. chia/cmds/passphrase.py +130 -0
  428. chia/cmds/passphrase_funcs.py +346 -0
  429. chia/cmds/peer.py +50 -0
  430. chia/cmds/peer_funcs.py +129 -0
  431. chia/cmds/plotnft.py +206 -0
  432. chia/cmds/plotnft_funcs.py +374 -0
  433. chia/cmds/plots.py +222 -0
  434. chia/cmds/plotters.py +17 -0
  435. chia/cmds/rpc.py +188 -0
  436. chia/cmds/show.py +71 -0
  437. chia/cmds/show_funcs.py +214 -0
  438. chia/cmds/signer.py +304 -0
  439. chia/cmds/sim.py +217 -0
  440. chia/cmds/sim_funcs.py +509 -0
  441. chia/cmds/start.py +24 -0
  442. chia/cmds/start_funcs.py +112 -0
  443. chia/cmds/stop.py +61 -0
  444. chia/cmds/units.py +11 -0
  445. chia/cmds/wallet.py +1745 -0
  446. chia/cmds/wallet_funcs.py +1800 -0
  447. chia/consensus/__init__.py +0 -0
  448. chia/consensus/block_body_validation.py +515 -0
  449. chia/consensus/block_creation.py +525 -0
  450. chia/consensus/block_header_validation.py +1064 -0
  451. chia/consensus/block_record.py +32 -0
  452. chia/consensus/block_rewards.py +53 -0
  453. chia/consensus/block_root_validation.py +46 -0
  454. chia/consensus/blockchain.py +1100 -0
  455. chia/consensus/blockchain_interface.py +56 -0
  456. chia/consensus/coinbase.py +30 -0
  457. chia/consensus/condition_costs.py +9 -0
  458. chia/consensus/constants.py +49 -0
  459. chia/consensus/cost_calculator.py +15 -0
  460. chia/consensus/default_constants.py +90 -0
  461. chia/consensus/deficit.py +55 -0
  462. chia/consensus/difficulty_adjustment.py +412 -0
  463. chia/consensus/find_fork_point.py +111 -0
  464. chia/consensus/full_block_to_block_record.py +167 -0
  465. chia/consensus/get_block_challenge.py +106 -0
  466. chia/consensus/get_block_generator.py +26 -0
  467. chia/consensus/make_sub_epoch_summary.py +210 -0
  468. chia/consensus/multiprocess_validation.py +365 -0
  469. chia/consensus/pos_quality.py +19 -0
  470. chia/consensus/pot_iterations.py +67 -0
  471. chia/consensus/puzzles/__init__.py +0 -0
  472. chia/consensus/puzzles/chialisp_deserialisation.clsp +69 -0
  473. chia/consensus/puzzles/chialisp_deserialisation.clsp.hex +1 -0
  474. chia/consensus/puzzles/rom_bootstrap_generator.clsp +37 -0
  475. chia/consensus/puzzles/rom_bootstrap_generator.clsp.hex +1 -0
  476. chia/consensus/vdf_info_computation.py +156 -0
  477. chia/daemon/__init__.py +0 -0
  478. chia/daemon/client.py +233 -0
  479. chia/daemon/keychain_proxy.py +501 -0
  480. chia/daemon/keychain_server.py +365 -0
  481. chia/daemon/server.py +1616 -0
  482. chia/daemon/windows_signal.py +56 -0
  483. chia/data_layer/__init__.py +0 -0
  484. chia/data_layer/data_layer.py +1303 -0
  485. chia/data_layer/data_layer_api.py +25 -0
  486. chia/data_layer/data_layer_errors.py +50 -0
  487. chia/data_layer/data_layer_server.py +170 -0
  488. chia/data_layer/data_layer_util.py +985 -0
  489. chia/data_layer/data_layer_wallet.py +1315 -0
  490. chia/data_layer/data_store.py +2267 -0
  491. chia/data_layer/dl_wallet_store.py +407 -0
  492. chia/data_layer/download_data.py +389 -0
  493. chia/data_layer/puzzles/__init__.py +0 -0
  494. chia/data_layer/puzzles/graftroot_dl_offers.clsp +100 -0
  495. chia/data_layer/puzzles/graftroot_dl_offers.clsp.hex +1 -0
  496. chia/data_layer/s3_plugin_config.yml +33 -0
  497. chia/data_layer/s3_plugin_service.py +468 -0
  498. chia/data_layer/util/__init__.py +0 -0
  499. chia/data_layer/util/benchmark.py +108 -0
  500. chia/data_layer/util/plugin.py +41 -0
  501. chia/farmer/__init__.py +0 -0
  502. chia/farmer/farmer.py +920 -0
  503. chia/farmer/farmer_api.py +814 -0
  504. chia/full_node/__init__.py +0 -0
  505. chia/full_node/bitcoin_fee_estimator.py +85 -0
  506. chia/full_node/block_height_map.py +271 -0
  507. chia/full_node/block_store.py +570 -0
  508. chia/full_node/bundle_tools.py +19 -0
  509. chia/full_node/coin_store.py +646 -0
  510. chia/full_node/fee_estimate.py +54 -0
  511. chia/full_node/fee_estimate_store.py +24 -0
  512. chia/full_node/fee_estimation.py +93 -0
  513. chia/full_node/fee_estimator.py +90 -0
  514. chia/full_node/fee_estimator_constants.py +38 -0
  515. chia/full_node/fee_estimator_interface.py +42 -0
  516. chia/full_node/fee_history.py +26 -0
  517. chia/full_node/fee_tracker.py +564 -0
  518. chia/full_node/full_node.py +3052 -0
  519. chia/full_node/full_node_api.py +1974 -0
  520. chia/full_node/full_node_store.py +1033 -0
  521. chia/full_node/hint_management.py +56 -0
  522. chia/full_node/hint_store.py +94 -0
  523. chia/full_node/mempool.py +583 -0
  524. chia/full_node/mempool_check_conditions.py +177 -0
  525. chia/full_node/mempool_manager.py +858 -0
  526. chia/full_node/pending_tx_cache.py +112 -0
  527. chia/full_node/puzzles/__init__.py +0 -0
  528. chia/full_node/puzzles/block_program_zero.clsp +14 -0
  529. chia/full_node/puzzles/block_program_zero.clsp.hex +1 -0
  530. chia/full_node/puzzles/decompress_coin_spend_entry.clsp +5 -0
  531. chia/full_node/puzzles/decompress_coin_spend_entry.clsp.hex +1 -0
  532. chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp +7 -0
  533. chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp.hex +1 -0
  534. chia/full_node/puzzles/decompress_puzzle.clsp +6 -0
  535. chia/full_node/puzzles/decompress_puzzle.clsp.hex +1 -0
  536. chia/full_node/signage_point.py +16 -0
  537. chia/full_node/subscriptions.py +248 -0
  538. chia/full_node/sync_store.py +145 -0
  539. chia/full_node/tx_processing_queue.py +78 -0
  540. chia/full_node/weight_proof.py +1719 -0
  541. chia/harvester/__init__.py +0 -0
  542. chia/harvester/harvester.py +271 -0
  543. chia/harvester/harvester_api.py +374 -0
  544. chia/introducer/__init__.py +0 -0
  545. chia/introducer/introducer.py +120 -0
  546. chia/introducer/introducer_api.py +64 -0
  547. chia/legacy/__init__.py +0 -0
  548. chia/legacy/keyring.py +154 -0
  549. chia/plot_sync/__init__.py +0 -0
  550. chia/plot_sync/delta.py +61 -0
  551. chia/plot_sync/exceptions.py +56 -0
  552. chia/plot_sync/receiver.py +385 -0
  553. chia/plot_sync/sender.py +337 -0
  554. chia/plot_sync/util.py +43 -0
  555. chia/plotters/__init__.py +0 -0
  556. chia/plotters/bladebit.py +388 -0
  557. chia/plotters/chiapos.py +63 -0
  558. chia/plotters/madmax.py +224 -0
  559. chia/plotters/plotters.py +577 -0
  560. chia/plotters/plotters_util.py +131 -0
  561. chia/plotting/__init__.py +0 -0
  562. chia/plotting/cache.py +212 -0
  563. chia/plotting/check_plots.py +283 -0
  564. chia/plotting/create_plots.py +278 -0
  565. chia/plotting/manager.py +436 -0
  566. chia/plotting/util.py +324 -0
  567. chia/pools/__init__.py +0 -0
  568. chia/pools/pool_config.py +110 -0
  569. chia/pools/pool_puzzles.py +459 -0
  570. chia/pools/pool_wallet.py +926 -0
  571. chia/pools/pool_wallet_info.py +118 -0
  572. chia/pools/puzzles/__init__.py +0 -0
  573. chia/pools/puzzles/pool_member_innerpuz.clsp +70 -0
  574. chia/pools/puzzles/pool_member_innerpuz.clsp.hex +1 -0
  575. chia/pools/puzzles/pool_waitingroom_innerpuz.clsp +69 -0
  576. chia/pools/puzzles/pool_waitingroom_innerpuz.clsp.hex +1 -0
  577. chia/protocols/__init__.py +0 -0
  578. chia/protocols/farmer_protocol.py +102 -0
  579. chia/protocols/full_node_protocol.py +219 -0
  580. chia/protocols/harvester_protocol.py +216 -0
  581. chia/protocols/introducer_protocol.py +26 -0
  582. chia/protocols/pool_protocol.py +177 -0
  583. chia/protocols/protocol_message_types.py +139 -0
  584. chia/protocols/protocol_state_machine.py +87 -0
  585. chia/protocols/protocol_timing.py +7 -0
  586. chia/protocols/shared_protocol.py +86 -0
  587. chia/protocols/timelord_protocol.py +93 -0
  588. chia/protocols/wallet_protocol.py +401 -0
  589. chia/py.typed +0 -0
  590. chia/rpc/__init__.py +0 -0
  591. chia/rpc/crawler_rpc_api.py +75 -0
  592. chia/rpc/data_layer_rpc_api.py +639 -0
  593. chia/rpc/data_layer_rpc_client.py +188 -0
  594. chia/rpc/data_layer_rpc_util.py +62 -0
  595. chia/rpc/farmer_rpc_api.py +360 -0
  596. chia/rpc/farmer_rpc_client.py +86 -0
  597. chia/rpc/full_node_rpc_api.py +954 -0
  598. chia/rpc/full_node_rpc_client.py +292 -0
  599. chia/rpc/harvester_rpc_api.py +136 -0
  600. chia/rpc/harvester_rpc_client.py +54 -0
  601. chia/rpc/rpc_client.py +144 -0
  602. chia/rpc/rpc_server.py +447 -0
  603. chia/rpc/timelord_rpc_api.py +27 -0
  604. chia/rpc/util.py +293 -0
  605. chia/rpc/wallet_request_types.py +688 -0
  606. chia/rpc/wallet_rpc_api.py +4779 -0
  607. chia/rpc/wallet_rpc_client.py +1844 -0
  608. chia/seeder/__init__.py +0 -0
  609. chia/seeder/crawl_store.py +427 -0
  610. chia/seeder/crawler.py +423 -0
  611. chia/seeder/crawler_api.py +129 -0
  612. chia/seeder/dns_server.py +544 -0
  613. chia/seeder/peer_record.py +146 -0
  614. chia/seeder/start_crawler.py +88 -0
  615. chia/server/__init__.py +0 -0
  616. chia/server/address_manager.py +658 -0
  617. chia/server/address_manager_store.py +237 -0
  618. chia/server/api_protocol.py +11 -0
  619. chia/server/capabilities.py +24 -0
  620. chia/server/chia_policy.py +345 -0
  621. chia/server/introducer_peers.py +76 -0
  622. chia/server/node_discovery.py +718 -0
  623. chia/server/outbound_message.py +33 -0
  624. chia/server/rate_limit_numbers.py +204 -0
  625. chia/server/rate_limits.py +113 -0
  626. chia/server/server.py +720 -0
  627. chia/server/signal_handlers.py +117 -0
  628. chia/server/ssl_context.py +32 -0
  629. chia/server/start_data_layer.py +137 -0
  630. chia/server/start_farmer.py +86 -0
  631. chia/server/start_full_node.py +106 -0
  632. chia/server/start_harvester.py +80 -0
  633. chia/server/start_introducer.py +69 -0
  634. chia/server/start_service.py +328 -0
  635. chia/server/start_timelord.py +82 -0
  636. chia/server/start_wallet.py +109 -0
  637. chia/server/upnp.py +117 -0
  638. chia/server/ws_connection.py +752 -0
  639. chia/simulator/__init__.py +0 -0
  640. chia/simulator/block_tools.py +2053 -0
  641. chia/simulator/full_node_simulator.py +802 -0
  642. chia/simulator/keyring.py +128 -0
  643. chia/simulator/setup_services.py +505 -0
  644. chia/simulator/simulator_constants.py +13 -0
  645. chia/simulator/simulator_full_node_rpc_api.py +101 -0
  646. chia/simulator/simulator_full_node_rpc_client.py +62 -0
  647. chia/simulator/simulator_protocol.py +29 -0
  648. chia/simulator/simulator_test_tools.py +163 -0
  649. chia/simulator/socket.py +27 -0
  650. chia/simulator/ssl_certs.py +114 -0
  651. chia/simulator/ssl_certs_1.py +699 -0
  652. chia/simulator/ssl_certs_10.py +699 -0
  653. chia/simulator/ssl_certs_2.py +699 -0
  654. chia/simulator/ssl_certs_3.py +699 -0
  655. chia/simulator/ssl_certs_4.py +699 -0
  656. chia/simulator/ssl_certs_5.py +699 -0
  657. chia/simulator/ssl_certs_6.py +699 -0
  658. chia/simulator/ssl_certs_7.py +699 -0
  659. chia/simulator/ssl_certs_8.py +699 -0
  660. chia/simulator/ssl_certs_9.py +699 -0
  661. chia/simulator/start_simulator.py +135 -0
  662. chia/simulator/wallet_tools.py +245 -0
  663. chia/ssl/__init__.py +0 -0
  664. chia/ssl/chia_ca.crt +19 -0
  665. chia/ssl/chia_ca.key +28 -0
  666. chia/ssl/create_ssl.py +249 -0
  667. chia/ssl/dst_root_ca.pem +20 -0
  668. chia/timelord/__init__.py +0 -0
  669. chia/timelord/iters_from_block.py +50 -0
  670. chia/timelord/timelord.py +1202 -0
  671. chia/timelord/timelord_api.py +132 -0
  672. chia/timelord/timelord_launcher.py +188 -0
  673. chia/timelord/timelord_state.py +244 -0
  674. chia/timelord/types.py +22 -0
  675. chia/types/__init__.py +0 -0
  676. chia/types/aliases.py +35 -0
  677. chia/types/block_protocol.py +20 -0
  678. chia/types/blockchain_format/__init__.py +0 -0
  679. chia/types/blockchain_format/classgroup.py +5 -0
  680. chia/types/blockchain_format/coin.py +28 -0
  681. chia/types/blockchain_format/foliage.py +8 -0
  682. chia/types/blockchain_format/pool_target.py +5 -0
  683. chia/types/blockchain_format/program.py +270 -0
  684. chia/types/blockchain_format/proof_of_space.py +135 -0
  685. chia/types/blockchain_format/reward_chain_block.py +6 -0
  686. chia/types/blockchain_format/serialized_program.py +5 -0
  687. chia/types/blockchain_format/sized_bytes.py +11 -0
  688. chia/types/blockchain_format/slots.py +9 -0
  689. chia/types/blockchain_format/sub_epoch_summary.py +5 -0
  690. chia/types/blockchain_format/tree_hash.py +72 -0
  691. chia/types/blockchain_format/vdf.py +86 -0
  692. chia/types/clvm_cost.py +13 -0
  693. chia/types/coin_record.py +43 -0
  694. chia/types/coin_spend.py +115 -0
  695. chia/types/condition_opcodes.py +73 -0
  696. chia/types/condition_with_args.py +17 -0
  697. chia/types/eligible_coin_spends.py +364 -0
  698. chia/types/end_of_slot_bundle.py +5 -0
  699. chia/types/fee_rate.py +38 -0
  700. chia/types/full_block.py +5 -0
  701. chia/types/generator_types.py +14 -0
  702. chia/types/header_block.py +5 -0
  703. chia/types/internal_mempool_item.py +19 -0
  704. chia/types/mempool_inclusion_status.py +9 -0
  705. chia/types/mempool_item.py +85 -0
  706. chia/types/mempool_submission_status.py +30 -0
  707. chia/types/mojos.py +7 -0
  708. chia/types/peer_info.py +64 -0
  709. chia/types/signing_mode.py +29 -0
  710. chia/types/spend_bundle.py +31 -0
  711. chia/types/spend_bundle_conditions.py +7 -0
  712. chia/types/transaction_queue_entry.py +55 -0
  713. chia/types/unfinished_block.py +5 -0
  714. chia/types/unfinished_header_block.py +37 -0
  715. chia/types/weight_proof.py +50 -0
  716. chia/util/__init__.py +0 -0
  717. chia/util/action_scope.py +168 -0
  718. chia/util/api_decorators.py +89 -0
  719. chia/util/async_pool.py +224 -0
  720. chia/util/augmented_chain.py +130 -0
  721. chia/util/batches.py +39 -0
  722. chia/util/bech32m.py +123 -0
  723. chia/util/beta_metrics.py +118 -0
  724. chia/util/block_cache.py +56 -0
  725. chia/util/byte_types.py +10 -0
  726. chia/util/check_fork_next_block.py +32 -0
  727. chia/util/chia_logging.py +124 -0
  728. chia/util/chia_version.py +33 -0
  729. chia/util/collection.py +17 -0
  730. chia/util/condition_tools.py +201 -0
  731. chia/util/config.py +366 -0
  732. chia/util/cpu.py +20 -0
  733. chia/util/db_synchronous.py +21 -0
  734. chia/util/db_version.py +30 -0
  735. chia/util/db_wrapper.py +427 -0
  736. chia/util/default_root.py +10 -0
  737. chia/util/dump_keyring.py +93 -0
  738. chia/util/english.txt +2048 -0
  739. chia/util/errors.py +351 -0
  740. chia/util/file_keyring.py +480 -0
  741. chia/util/files.py +95 -0
  742. chia/util/full_block_utils.py +321 -0
  743. chia/util/generator_tools.py +62 -0
  744. chia/util/hash.py +29 -0
  745. chia/util/initial-config.yaml +675 -0
  746. chia/util/inline_executor.py +24 -0
  747. chia/util/ints.py +19 -0
  748. chia/util/json_util.py +41 -0
  749. chia/util/keychain.py +673 -0
  750. chia/util/keyring_wrapper.py +266 -0
  751. chia/util/limited_semaphore.py +39 -0
  752. chia/util/lock.py +47 -0
  753. chia/util/log_exceptions.py +29 -0
  754. chia/util/logging.py +34 -0
  755. chia/util/lru_cache.py +29 -0
  756. chia/util/math.py +20 -0
  757. chia/util/network.py +240 -0
  758. chia/util/paginator.py +46 -0
  759. chia/util/path.py +29 -0
  760. chia/util/permissions.py +19 -0
  761. chia/util/pprint.py +40 -0
  762. chia/util/prev_transaction_block.py +23 -0
  763. chia/util/priority_mutex.py +92 -0
  764. chia/util/profiler.py +194 -0
  765. chia/util/recursive_replace.py +22 -0
  766. chia/util/safe_cancel_task.py +14 -0
  767. chia/util/service_groups.py +47 -0
  768. chia/util/setproctitle.py +20 -0
  769. chia/util/significant_bits.py +30 -0
  770. chia/util/ssl_check.py +213 -0
  771. chia/util/streamable.py +654 -0
  772. chia/util/task_timing.py +378 -0
  773. chia/util/timing.py +64 -0
  774. chia/util/vdf_prover.py +31 -0
  775. chia/util/ws_message.py +66 -0
  776. chia/wallet/__init__.py +0 -0
  777. chia/wallet/cat_wallet/__init__.py +0 -0
  778. chia/wallet/cat_wallet/cat_constants.py +75 -0
  779. chia/wallet/cat_wallet/cat_info.py +47 -0
  780. chia/wallet/cat_wallet/cat_outer_puzzle.py +120 -0
  781. chia/wallet/cat_wallet/cat_utils.py +163 -0
  782. chia/wallet/cat_wallet/cat_wallet.py +869 -0
  783. chia/wallet/cat_wallet/dao_cat_info.py +28 -0
  784. chia/wallet/cat_wallet/dao_cat_wallet.py +669 -0
  785. chia/wallet/cat_wallet/lineage_store.py +74 -0
  786. chia/wallet/cat_wallet/puzzles/__init__.py +0 -0
  787. chia/wallet/cat_wallet/puzzles/cat_truths.clib +31 -0
  788. chia/wallet/cat_wallet/puzzles/cat_v2.clsp +397 -0
  789. chia/wallet/cat_wallet/puzzles/cat_v2.clsp.hex +1 -0
  790. chia/wallet/cat_wallet/puzzles/delegated_tail.clsp +25 -0
  791. chia/wallet/cat_wallet/puzzles/delegated_tail.clsp.hex +1 -0
  792. chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp +15 -0
  793. chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp.hex +1 -0
  794. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp +26 -0
  795. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp.hex +1 -0
  796. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp +42 -0
  797. chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp.hex +1 -0
  798. chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp +24 -0
  799. chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp.hex +1 -0
  800. chia/wallet/coin_selection.py +188 -0
  801. chia/wallet/conditions.py +1326 -0
  802. chia/wallet/dao_wallet/__init__.py +0 -0
  803. chia/wallet/dao_wallet/dao_info.py +61 -0
  804. chia/wallet/dao_wallet/dao_utils.py +810 -0
  805. chia/wallet/dao_wallet/dao_wallet.py +2121 -0
  806. chia/wallet/db_wallet/__init__.py +0 -0
  807. chia/wallet/db_wallet/db_wallet_puzzles.py +107 -0
  808. chia/wallet/derivation_record.py +30 -0
  809. chia/wallet/derive_keys.py +146 -0
  810. chia/wallet/did_wallet/__init__.py +0 -0
  811. chia/wallet/did_wallet/did_info.py +39 -0
  812. chia/wallet/did_wallet/did_wallet.py +1485 -0
  813. chia/wallet/did_wallet/did_wallet_puzzles.py +220 -0
  814. chia/wallet/did_wallet/puzzles/__init__.py +0 -0
  815. chia/wallet/did_wallet/puzzles/did_innerpuz.clsp +135 -0
  816. chia/wallet/did_wallet/puzzles/did_innerpuz.clsp.hex +1 -0
  817. chia/wallet/driver_protocol.py +26 -0
  818. chia/wallet/key_val_store.py +55 -0
  819. chia/wallet/lineage_proof.py +58 -0
  820. chia/wallet/nft_wallet/__init__.py +0 -0
  821. chia/wallet/nft_wallet/metadata_outer_puzzle.py +92 -0
  822. chia/wallet/nft_wallet/nft_info.py +120 -0
  823. chia/wallet/nft_wallet/nft_puzzles.py +305 -0
  824. chia/wallet/nft_wallet/nft_wallet.py +1686 -0
  825. chia/wallet/nft_wallet/ownership_outer_puzzle.py +101 -0
  826. chia/wallet/nft_wallet/puzzles/__init__.py +0 -0
  827. chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp +6 -0
  828. chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp.hex +1 -0
  829. chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp +6 -0
  830. chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp.hex +1 -0
  831. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp +30 -0
  832. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp.hex +1 -0
  833. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp +28 -0
  834. chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp.hex +1 -0
  835. chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp +100 -0
  836. chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp.hex +1 -0
  837. chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp +78 -0
  838. chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp.hex +1 -0
  839. chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp +74 -0
  840. chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp.hex +1 -0
  841. chia/wallet/nft_wallet/singleton_outer_puzzle.py +101 -0
  842. chia/wallet/nft_wallet/transfer_program_puzzle.py +82 -0
  843. chia/wallet/nft_wallet/uncurry_nft.py +217 -0
  844. chia/wallet/notification_manager.py +117 -0
  845. chia/wallet/notification_store.py +178 -0
  846. chia/wallet/outer_puzzles.py +84 -0
  847. chia/wallet/payment.py +34 -0
  848. chia/wallet/puzzle_drivers.py +118 -0
  849. chia/wallet/puzzles/__init__.py +0 -0
  850. chia/wallet/puzzles/augmented_condition.clsp +13 -0
  851. chia/wallet/puzzles/augmented_condition.clsp.hex +1 -0
  852. chia/wallet/puzzles/clawback/__init__.py +0 -0
  853. chia/wallet/puzzles/clawback/drivers.py +188 -0
  854. chia/wallet/puzzles/clawback/metadata.py +38 -0
  855. chia/wallet/puzzles/clawback/puzzle_decorator.py +67 -0
  856. chia/wallet/puzzles/condition_codes.clib +77 -0
  857. chia/wallet/puzzles/curry-and-treehash.clib +102 -0
  858. chia/wallet/puzzles/curry.clib +135 -0
  859. chia/wallet/puzzles/curry_by_index.clib +16 -0
  860. chia/wallet/puzzles/dao_cat_eve.clsp +17 -0
  861. chia/wallet/puzzles/dao_cat_eve.clsp.hex +1 -0
  862. chia/wallet/puzzles/dao_cat_launcher.clsp +36 -0
  863. chia/wallet/puzzles/dao_cat_launcher.clsp.hex +1 -0
  864. chia/wallet/puzzles/dao_finished_state.clsp +35 -0
  865. chia/wallet/puzzles/dao_finished_state.clsp.hex +1 -0
  866. chia/wallet/puzzles/dao_finished_state.clsp.hex.sha256tree +1 -0
  867. chia/wallet/puzzles/dao_lockup.clsp +288 -0
  868. chia/wallet/puzzles/dao_lockup.clsp.hex +1 -0
  869. chia/wallet/puzzles/dao_lockup.clsp.hex.sha256tree +1 -0
  870. chia/wallet/puzzles/dao_proposal.clsp +377 -0
  871. chia/wallet/puzzles/dao_proposal.clsp.hex +1 -0
  872. chia/wallet/puzzles/dao_proposal.clsp.hex.sha256tree +1 -0
  873. chia/wallet/puzzles/dao_proposal_timer.clsp +78 -0
  874. chia/wallet/puzzles/dao_proposal_timer.clsp.hex +1 -0
  875. chia/wallet/puzzles/dao_proposal_timer.clsp.hex.sha256tree +1 -0
  876. chia/wallet/puzzles/dao_proposal_validator.clsp +87 -0
  877. chia/wallet/puzzles/dao_proposal_validator.clsp.hex +1 -0
  878. chia/wallet/puzzles/dao_proposal_validator.clsp.hex.sha256tree +1 -0
  879. chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp +240 -0
  880. chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex +1 -0
  881. chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex.sha256tree +1 -0
  882. chia/wallet/puzzles/dao_treasury.clsp +115 -0
  883. chia/wallet/puzzles/dao_treasury.clsp.hex +1 -0
  884. chia/wallet/puzzles/dao_update_proposal.clsp +44 -0
  885. chia/wallet/puzzles/dao_update_proposal.clsp.hex +1 -0
  886. chia/wallet/puzzles/deployed_puzzle_hashes.json +67 -0
  887. chia/wallet/puzzles/json.clib +25 -0
  888. chia/wallet/puzzles/load_clvm.py +162 -0
  889. chia/wallet/puzzles/merkle_utils.clib +18 -0
  890. chia/wallet/puzzles/notification.clsp +7 -0
  891. chia/wallet/puzzles/notification.clsp.hex +1 -0
  892. chia/wallet/puzzles/p2_1_of_n.clsp +22 -0
  893. chia/wallet/puzzles/p2_1_of_n.clsp.hex +1 -0
  894. chia/wallet/puzzles/p2_conditions.clsp +3 -0
  895. chia/wallet/puzzles/p2_conditions.clsp.hex +1 -0
  896. chia/wallet/puzzles/p2_conditions.py +27 -0
  897. chia/wallet/puzzles/p2_delegated_conditions.clsp +18 -0
  898. chia/wallet/puzzles/p2_delegated_conditions.clsp.hex +1 -0
  899. chia/wallet/puzzles/p2_delegated_conditions.py +22 -0
  900. chia/wallet/puzzles/p2_delegated_puzzle.clsp +19 -0
  901. chia/wallet/puzzles/p2_delegated_puzzle.clsp.hex +1 -0
  902. chia/wallet/puzzles/p2_delegated_puzzle.py +35 -0
  903. chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp +91 -0
  904. chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp.hex +1 -0
  905. chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.py +161 -0
  906. chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp +108 -0
  907. chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp.hex +1 -0
  908. chia/wallet/puzzles/p2_m_of_n_delegate_direct.py +22 -0
  909. chia/wallet/puzzles/p2_parent.clsp +19 -0
  910. chia/wallet/puzzles/p2_parent.clsp.hex +1 -0
  911. chia/wallet/puzzles/p2_puzzle_hash.clsp +18 -0
  912. chia/wallet/puzzles/p2_puzzle_hash.clsp.hex +1 -0
  913. chia/wallet/puzzles/p2_puzzle_hash.py +28 -0
  914. chia/wallet/puzzles/p2_singleton.clsp +30 -0
  915. chia/wallet/puzzles/p2_singleton.clsp.hex +1 -0
  916. chia/wallet/puzzles/p2_singleton_aggregator.clsp +81 -0
  917. chia/wallet/puzzles/p2_singleton_aggregator.clsp.hex +1 -0
  918. chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp +50 -0
  919. chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp.hex +1 -0
  920. chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp +47 -0
  921. chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp.hex +1 -0
  922. chia/wallet/puzzles/puzzle_utils.py +34 -0
  923. chia/wallet/puzzles/settlement_payments.clsp +49 -0
  924. chia/wallet/puzzles/settlement_payments.clsp.hex +1 -0
  925. chia/wallet/puzzles/sha256tree.clib +11 -0
  926. chia/wallet/puzzles/singleton_launcher.clsp +16 -0
  927. chia/wallet/puzzles/singleton_launcher.clsp.hex +1 -0
  928. chia/wallet/puzzles/singleton_top_layer.clsp +177 -0
  929. chia/wallet/puzzles/singleton_top_layer.clsp.hex +1 -0
  930. chia/wallet/puzzles/singleton_top_layer.py +295 -0
  931. chia/wallet/puzzles/singleton_top_layer_v1_1.clsp +107 -0
  932. chia/wallet/puzzles/singleton_top_layer_v1_1.clsp.hex +1 -0
  933. chia/wallet/puzzles/singleton_top_layer_v1_1.py +344 -0
  934. chia/wallet/puzzles/singleton_truths.clib +21 -0
  935. chia/wallet/puzzles/tails.py +344 -0
  936. chia/wallet/puzzles/utility_macros.clib +48 -0
  937. chia/wallet/signer_protocol.py +126 -0
  938. chia/wallet/singleton.py +106 -0
  939. chia/wallet/singleton_record.py +30 -0
  940. chia/wallet/trade_manager.py +1088 -0
  941. chia/wallet/trade_record.py +67 -0
  942. chia/wallet/trading/__init__.py +0 -0
  943. chia/wallet/trading/offer.py +703 -0
  944. chia/wallet/trading/trade_status.py +13 -0
  945. chia/wallet/trading/trade_store.py +526 -0
  946. chia/wallet/transaction_record.py +143 -0
  947. chia/wallet/transaction_sorting.py +14 -0
  948. chia/wallet/uncurried_puzzle.py +17 -0
  949. chia/wallet/util/__init__.py +0 -0
  950. chia/wallet/util/address_type.py +55 -0
  951. chia/wallet/util/blind_signer_tl.py +168 -0
  952. chia/wallet/util/clvm_streamable.py +203 -0
  953. chia/wallet/util/compute_hints.py +66 -0
  954. chia/wallet/util/compute_memos.py +45 -0
  955. chia/wallet/util/curry_and_treehash.py +90 -0
  956. chia/wallet/util/debug_spend_bundle.py +234 -0
  957. chia/wallet/util/merkle_tree.py +100 -0
  958. chia/wallet/util/merkle_utils.py +102 -0
  959. chia/wallet/util/new_peak_queue.py +82 -0
  960. chia/wallet/util/notifications.py +12 -0
  961. chia/wallet/util/peer_request_cache.py +174 -0
  962. chia/wallet/util/puzzle_compression.py +96 -0
  963. chia/wallet/util/puzzle_decorator.py +100 -0
  964. chia/wallet/util/puzzle_decorator_type.py +7 -0
  965. chia/wallet/util/query_filter.py +60 -0
  966. chia/wallet/util/transaction_type.py +23 -0
  967. chia/wallet/util/tx_config.py +158 -0
  968. chia/wallet/util/wallet_sync_utils.py +348 -0
  969. chia/wallet/util/wallet_types.py +65 -0
  970. chia/wallet/vc_wallet/__init__.py +0 -0
  971. chia/wallet/vc_wallet/cr_cat_drivers.py +663 -0
  972. chia/wallet/vc_wallet/cr_cat_wallet.py +875 -0
  973. chia/wallet/vc_wallet/cr_outer_puzzle.py +102 -0
  974. chia/wallet/vc_wallet/cr_puzzles/__init__.py +0 -0
  975. chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp +3 -0
  976. chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp.hex +1 -0
  977. chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp +304 -0
  978. chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp.hex +1 -0
  979. chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp +45 -0
  980. chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp.hex +1 -0
  981. chia/wallet/vc_wallet/vc_drivers.py +838 -0
  982. chia/wallet/vc_wallet/vc_puzzles/__init__.py +0 -0
  983. chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp +30 -0
  984. chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp.hex +1 -0
  985. chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp +75 -0
  986. chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp.hex +1 -0
  987. chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp +32 -0
  988. chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp.hex +1 -0
  989. chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp +80 -0
  990. chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp.hex +1 -0
  991. chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp +163 -0
  992. chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp.hex +1 -0
  993. chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp +16 -0
  994. chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp.hex +1 -0
  995. chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp +74 -0
  996. chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp.hex +1 -0
  997. chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp +23 -0
  998. chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp.hex +1 -0
  999. chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp +64 -0
  1000. chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp.hex +1 -0
  1001. chia/wallet/vc_wallet/vc_store.py +263 -0
  1002. chia/wallet/vc_wallet/vc_wallet.py +638 -0
  1003. chia/wallet/wallet.py +698 -0
  1004. chia/wallet/wallet_action_scope.py +95 -0
  1005. chia/wallet/wallet_blockchain.py +244 -0
  1006. chia/wallet/wallet_coin_record.py +72 -0
  1007. chia/wallet/wallet_coin_store.py +351 -0
  1008. chia/wallet/wallet_info.py +36 -0
  1009. chia/wallet/wallet_interested_store.py +188 -0
  1010. chia/wallet/wallet_nft_store.py +279 -0
  1011. chia/wallet/wallet_node.py +1769 -0
  1012. chia/wallet/wallet_node_api.py +201 -0
  1013. chia/wallet/wallet_pool_store.py +120 -0
  1014. chia/wallet/wallet_protocol.py +90 -0
  1015. chia/wallet/wallet_puzzle_store.py +365 -0
  1016. chia/wallet/wallet_retry_store.py +70 -0
  1017. chia/wallet/wallet_singleton_store.py +258 -0
  1018. chia/wallet/wallet_spend_bundle.py +41 -0
  1019. chia/wallet/wallet_state_manager.py +2820 -0
  1020. chia/wallet/wallet_transaction_store.py +470 -0
  1021. chia/wallet/wallet_user_store.py +110 -0
  1022. chia/wallet/wallet_weight_proof_handler.py +126 -0
  1023. chia_blockchain-2.4.4.dist-info/LICENSE +201 -0
  1024. chia_blockchain-2.4.4.dist-info/METADATA +161 -0
  1025. chia_blockchain-2.4.4.dist-info/RECORD +1028 -0
  1026. chia_blockchain-2.4.4.dist-info/WHEEL +4 -0
  1027. chia_blockchain-2.4.4.dist-info/entry_points.txt +17 -0
  1028. mozilla-ca/cacert.pem +3666 -0
chia/farmer/farmer.py ADDED
@@ -0,0 +1,920 @@
1
+ from __future__ import annotations
2
+
3
+ import asyncio
4
+ import contextlib
5
+ import json
6
+ import logging
7
+ import sys
8
+ import time
9
+ import traceback
10
+ from dataclasses import dataclass
11
+ from math import floor
12
+ from pathlib import Path
13
+ from typing import TYPE_CHECKING, Any, AsyncIterator, ClassVar, Dict, List, Optional, Set, Tuple, Union, cast
14
+
15
+ import aiohttp
16
+ from chia_rs import AugSchemeMPL, G1Element, G2Element, PrivateKey
17
+
18
+ from chia.consensus.constants import ConsensusConstants
19
+ from chia.daemon.keychain_proxy import KeychainProxy, connect_to_keychain_and_validate, wrap_local_keychain
20
+ from chia.plot_sync.delta import Delta
21
+ from chia.plot_sync.receiver import Receiver
22
+ from chia.pools.pool_config import PoolWalletConfig, load_pool_config, update_pool_url
23
+ from chia.protocols import farmer_protocol, harvester_protocol
24
+ from chia.protocols.pool_protocol import (
25
+ AuthenticationPayload,
26
+ ErrorResponse,
27
+ GetFarmerResponse,
28
+ PoolErrorCode,
29
+ PostFarmerPayload,
30
+ PostFarmerRequest,
31
+ PutFarmerPayload,
32
+ PutFarmerRequest,
33
+ get_current_authentication_token,
34
+ )
35
+ from chia.protocols.protocol_message_types import ProtocolMessageTypes
36
+ from chia.rpc.rpc_server import StateChangedProtocol, default_get_connections
37
+ from chia.server.outbound_message import NodeType, make_msg
38
+ from chia.server.server import ChiaServer, ssl_context_for_root
39
+ from chia.server.ws_connection import WSChiaConnection
40
+ from chia.ssl.create_ssl import get_mozilla_ca_crt
41
+ from chia.types.blockchain_format.proof_of_space import ProofOfSpace
42
+ from chia.types.blockchain_format.sized_bytes import bytes32
43
+ from chia.util.bech32m import decode_puzzle_hash, encode_puzzle_hash
44
+ from chia.util.byte_types import hexstr_to_bytes
45
+ from chia.util.config import config_path_for_filename, load_config, lock_and_load_config, save_config
46
+ from chia.util.errors import KeychainProxyConnectionFailure
47
+ from chia.util.hash import std_hash
48
+ from chia.util.ints import uint8, uint16, uint32, uint64
49
+ from chia.util.keychain import Keychain
50
+ from chia.util.logging import TimedDuplicateFilter
51
+ from chia.util.profiler import profile_task
52
+ from chia.wallet.derive_keys import (
53
+ find_authentication_sk,
54
+ find_owner_sk,
55
+ master_sk_to_farmer_sk,
56
+ master_sk_to_pool_sk,
57
+ match_address_to_sk,
58
+ )
59
+ from chia.wallet.puzzles.singleton_top_layer import SINGLETON_MOD
60
+
61
+ singleton_mod_hash = SINGLETON_MOD.get_tree_hash()
62
+
63
+ log = logging.getLogger(__name__)
64
+
65
+ UPDATE_POOL_INFO_INTERVAL: int = 3600
66
+ UPDATE_POOL_INFO_FAILURE_RETRY_INTERVAL: int = 120
67
+ UPDATE_POOL_FARMER_INFO_INTERVAL: int = 300
68
+
69
+
70
+ @dataclass(frozen=True)
71
+ class GetPoolInfoResult:
72
+ pool_info: Dict[str, Any]
73
+ new_pool_url: Optional[str]
74
+
75
+
76
+ def strip_old_entries(pairs: List[Tuple[float, Any]], before: float) -> List[Tuple[float, Any]]:
77
+ for index, [timestamp, points] in enumerate(pairs):
78
+ if timestamp >= before:
79
+ if index == 0:
80
+ return pairs
81
+ if index > 0:
82
+ return pairs[index:]
83
+ return []
84
+
85
+
86
+ def increment_pool_stats(
87
+ pool_states: Dict[bytes32, Any],
88
+ p2_singleton_puzzlehash: bytes32,
89
+ name: str,
90
+ current_time: float,
91
+ count: int = 1,
92
+ value: Optional[Union[int, Dict[str, Any]]] = None,
93
+ ) -> None:
94
+ if p2_singleton_puzzlehash not in pool_states:
95
+ return
96
+ pool_state = pool_states[p2_singleton_puzzlehash]
97
+ if f"{name}_since_start" in pool_state:
98
+ pool_state[f"{name}_since_start"] += count
99
+ if f"{name}_24h" in pool_state:
100
+ if value is None:
101
+ pool_state[f"{name}_24h"].append((uint32(current_time), pool_state["current_difficulty"]))
102
+ else:
103
+ pool_state[f"{name}_24h"].append((uint32(current_time), value))
104
+
105
+ # Age out old 24h information for every signage point regardless
106
+ # of any failures. Note that this still lets old data remain if
107
+ # the client isn't receiving signage points.
108
+ cutoff_24h = current_time - (24 * 60 * 60)
109
+ pool_state[f"{name}_24h"] = strip_old_entries(pairs=pool_state[f"{name}_24h"], before=cutoff_24h)
110
+ return
111
+
112
+
113
+ """
114
+ HARVESTER PROTOCOL (FARMER <-> HARVESTER)
115
+ """
116
+
117
+
118
+ class Farmer:
119
+ if TYPE_CHECKING:
120
+ from chia.rpc.rpc_server import RpcServiceProtocol
121
+
122
+ _protocol_check: ClassVar[RpcServiceProtocol] = cast("Farmer", None)
123
+
124
+ def __init__(
125
+ self,
126
+ root_path: Path,
127
+ farmer_config: Dict[str, Any],
128
+ pool_config: Dict[str, Any],
129
+ consensus_constants: ConsensusConstants,
130
+ local_keychain: Optional[Keychain] = None,
131
+ ):
132
+ self.keychain_proxy: Optional[KeychainProxy] = None
133
+ self.local_keychain = local_keychain
134
+ self._root_path = root_path
135
+ self.config = farmer_config
136
+ self.pool_config = pool_config
137
+ # Keep track of all sps, keyed on challenge chain signage point hash
138
+ self.sps: Dict[bytes32, List[farmer_protocol.NewSignagePoint]] = {}
139
+
140
+ # Keep track of harvester plot identifier (str), target sp index, and PoSpace for each challenge
141
+ self.proofs_of_space: Dict[bytes32, List[Tuple[str, ProofOfSpace]]] = {}
142
+
143
+ # Quality string to plot identifier and challenge_hash, for use with harvester.RequestSignatures
144
+ self.quality_str_to_identifiers: Dict[bytes32, Tuple[str, bytes32, bytes32, bytes32]] = {}
145
+
146
+ # number of responses to each signage point
147
+ self.number_of_responses: Dict[bytes32, int] = {}
148
+
149
+ # A dictionary of keys to time added. These keys refer to keys in the above 4 dictionaries. This is used
150
+ # to periodically clear the memory
151
+ self.cache_add_time: Dict[bytes32, uint64] = {}
152
+
153
+ self.plot_sync_receivers: Dict[bytes32, Receiver] = {}
154
+
155
+ self.cache_clear_task: Optional[asyncio.Task[None]] = None
156
+ self.update_pool_state_task: Optional[asyncio.Task[None]] = None
157
+ self.constants = consensus_constants
158
+ self._shut_down = False
159
+ self.server: Any = None
160
+ self.state_changed_callback: Optional[StateChangedProtocol] = None
161
+ self.log = log
162
+ self.log.addFilter(TimedDuplicateFilter("No pool specific authentication_token_timeout.*", 60 * 10))
163
+ self.log.addFilter(TimedDuplicateFilter("No pool specific difficulty has been set.*", 60 * 10))
164
+
165
+ self.started = False
166
+ self.harvester_handshake_task: Optional[asyncio.Task[None]] = None
167
+
168
+ # From p2_singleton_puzzle_hash to pool state dict
169
+ self.pool_state: Dict[bytes32, Dict[str, Any]] = {}
170
+
171
+ # From p2_singleton to auth PrivateKey
172
+ self.authentication_keys: Dict[bytes32, PrivateKey] = {}
173
+
174
+ # Last time we updated pool_state based on the config file
175
+ self.last_config_access_time: float = 0
176
+
177
+ self.all_root_sks: List[PrivateKey] = []
178
+
179
+ # Use to find missing signage points. (new_signage_point, time)
180
+ self.prev_signage_point: Optional[Tuple[uint64, farmer_protocol.NewSignagePoint]] = None
181
+
182
+ @contextlib.asynccontextmanager
183
+ async def manage(self) -> AsyncIterator[None]:
184
+ async def start_task() -> None:
185
+ # `Farmer.setup_keys` returns `False` if there are no keys setup yet. In this case we just try until it
186
+ # succeeds or until we need to shut down.
187
+ while not self._shut_down:
188
+ if await self.setup_keys():
189
+ self.update_pool_state_task = asyncio.create_task(self._periodically_update_pool_state_task())
190
+ self.cache_clear_task = asyncio.create_task(self._periodically_clear_cache_and_refresh_task())
191
+ log.debug("start_task: initialized")
192
+ self.started = True
193
+ return
194
+ await asyncio.sleep(1)
195
+
196
+ if self.config.get("enable_profiler", False):
197
+ if sys.getprofile() is not None:
198
+ self.log.warning("not enabling profiler, getprofile() is already set")
199
+ else:
200
+ asyncio.create_task(profile_task(self._root_path, "farmer", self.log))
201
+
202
+ asyncio.create_task(start_task())
203
+ try:
204
+ yield
205
+ finally:
206
+ self._shut_down = True
207
+
208
+ if self.cache_clear_task is not None:
209
+ await self.cache_clear_task
210
+ if self.update_pool_state_task is not None:
211
+ await self.update_pool_state_task
212
+ if self.keychain_proxy is not None:
213
+ proxy = self.keychain_proxy
214
+ self.keychain_proxy = None
215
+ await proxy.close()
216
+ await asyncio.sleep(0.5) # https://docs.aiohttp.org/en/stable/client_advanced.html#graceful-shutdown
217
+ self.started = False
218
+
219
+ def get_connections(self, request_node_type: Optional[NodeType]) -> List[Dict[str, Any]]:
220
+ return default_get_connections(server=self.server, request_node_type=request_node_type)
221
+
222
+ async def ensure_keychain_proxy(self) -> KeychainProxy:
223
+ if self.keychain_proxy is None:
224
+ if self.local_keychain:
225
+ self.keychain_proxy = wrap_local_keychain(self.local_keychain, log=self.log)
226
+ else:
227
+ self.keychain_proxy = await connect_to_keychain_and_validate(self._root_path, self.log)
228
+ if not self.keychain_proxy:
229
+ raise KeychainProxyConnectionFailure()
230
+ return self.keychain_proxy
231
+
232
+ async def get_all_private_keys(self) -> List[Tuple[PrivateKey, bytes]]:
233
+ keychain_proxy = await self.ensure_keychain_proxy()
234
+ return await keychain_proxy.get_all_private_keys()
235
+
236
+ async def setup_keys(self) -> bool:
237
+ no_keys_error_str = "No keys exist. Please run 'chia keys generate' or open the UI."
238
+ try:
239
+ self.all_root_sks = [sk for sk, _ in await self.get_all_private_keys()]
240
+ except KeychainProxyConnectionFailure:
241
+ return False
242
+
243
+ self._private_keys = [master_sk_to_farmer_sk(sk) for sk in self.all_root_sks] + [
244
+ master_sk_to_pool_sk(sk) for sk in self.all_root_sks
245
+ ]
246
+
247
+ if len(self.get_public_keys()) == 0:
248
+ log.warning(no_keys_error_str)
249
+ return False
250
+
251
+ config = load_config(self._root_path, "config.yaml")
252
+ if "xch_target_address" not in self.config:
253
+ self.config = config["farmer"]
254
+ if "xch_target_address" not in self.pool_config:
255
+ self.pool_config = config["pool"]
256
+ if "xch_target_address" not in self.config or "xch_target_address" not in self.pool_config:
257
+ log.debug("xch_target_address missing in the config")
258
+ return False
259
+
260
+ # This is the farmer configuration
261
+ self.farmer_target_encoded = self.config["xch_target_address"]
262
+ self.farmer_target = decode_puzzle_hash(self.farmer_target_encoded)
263
+
264
+ self.pool_public_keys = [G1Element.from_bytes(bytes.fromhex(pk)) for pk in self.config["pool_public_keys"]]
265
+
266
+ # This is the self pooling configuration, which is only used for original self-pooled plots
267
+ self.pool_target_encoded = self.pool_config["xch_target_address"]
268
+ self.pool_target = decode_puzzle_hash(self.pool_target_encoded)
269
+ self.pool_sks_map = {bytes(key.get_g1()): key for key in self.get_private_keys()}
270
+
271
+ assert len(self.farmer_target) == 32
272
+ assert len(self.pool_target) == 32
273
+ if len(self.pool_sks_map) == 0:
274
+ log.warning(no_keys_error_str)
275
+ return False
276
+
277
+ return True
278
+
279
+ def _set_state_changed_callback(self, callback: StateChangedProtocol) -> None:
280
+ self.state_changed_callback = callback
281
+
282
+ async def on_connect(self, peer: WSChiaConnection) -> None:
283
+ self.state_changed("add_connection", {})
284
+
285
+ async def handshake_task() -> None:
286
+ # Wait until the task in `Farmer._start` is done so that we have keys available for the handshake. Bail out
287
+ # early if we need to shut down or if the harvester is not longer connected.
288
+ while not self.started and not self._shut_down and peer in self.server.get_connections():
289
+ await asyncio.sleep(1)
290
+
291
+ if self._shut_down:
292
+ log.debug("handshake_task: shutdown")
293
+ self.harvester_handshake_task = None
294
+ return
295
+
296
+ if peer not in self.server.get_connections():
297
+ log.debug("handshake_task: disconnected")
298
+ self.harvester_handshake_task = None
299
+ return
300
+
301
+ # Sends a handshake to the harvester
302
+ handshake = harvester_protocol.HarvesterHandshake(
303
+ self.get_public_keys(),
304
+ self.pool_public_keys,
305
+ )
306
+ msg = make_msg(ProtocolMessageTypes.harvester_handshake, handshake)
307
+ await peer.send_message(msg)
308
+ self.harvester_handshake_task = None
309
+
310
+ if peer.connection_type is NodeType.HARVESTER:
311
+ self.plot_sync_receivers[peer.peer_node_id] = Receiver(peer, self.plot_sync_callback)
312
+ self.harvester_handshake_task = asyncio.create_task(handshake_task())
313
+
314
+ def set_server(self, server: ChiaServer) -> None:
315
+ self.server = server
316
+
317
+ def state_changed(self, change: str, data: Dict[str, Any]) -> None:
318
+ if self.state_changed_callback is not None:
319
+ self.state_changed_callback(change, data)
320
+
321
+ def handle_failed_pool_response(self, p2_singleton_puzzle_hash: bytes32, error_message: str) -> None:
322
+ self.log.error(error_message)
323
+ increment_pool_stats(
324
+ self.pool_state,
325
+ p2_singleton_puzzle_hash,
326
+ "pool_errors",
327
+ time.time(),
328
+ value=ErrorResponse(uint16(PoolErrorCode.REQUEST_FAILED.value), error_message).to_json_dict(),
329
+ )
330
+
331
+ async def on_disconnect(self, connection: WSChiaConnection) -> None:
332
+ self.log.info(f"peer disconnected {connection.get_peer_logging()}")
333
+ self.state_changed("close_connection", {})
334
+ if connection.connection_type is NodeType.HARVESTER:
335
+ del self.plot_sync_receivers[connection.peer_node_id]
336
+ self.state_changed("harvester_removed", {"node_id": connection.peer_node_id})
337
+
338
+ async def plot_sync_callback(self, peer_id: bytes32, delta: Optional[Delta]) -> None:
339
+ log.debug(f"plot_sync_callback: peer_id {peer_id}, delta {delta}")
340
+ receiver: Receiver = self.plot_sync_receivers[peer_id]
341
+ harvester_updated: bool = delta is not None and not delta.empty()
342
+ if receiver.initial_sync() or harvester_updated:
343
+ self.state_changed("harvester_update", receiver.to_dict(True))
344
+
345
+ async def _pool_get_pool_info(self, pool_config: PoolWalletConfig) -> Optional[GetPoolInfoResult]:
346
+ try:
347
+ async with aiohttp.ClientSession(trust_env=True) as session:
348
+ url = f"{pool_config.pool_url}/pool_info"
349
+ async with session.get(url, ssl=ssl_context_for_root(get_mozilla_ca_crt(), log=self.log)) as resp:
350
+ if resp.ok:
351
+ response: Dict[str, Any] = json.loads(await resp.text())
352
+ self.log.info(f"GET /pool_info response: {response}")
353
+ new_pool_url: Optional[str] = None
354
+ response_url_str = f"{resp.url}"
355
+ if (
356
+ response_url_str != url
357
+ and len(resp.history) > 0
358
+ and all(r.status in {301, 308} for r in resp.history)
359
+ ):
360
+ new_pool_url = response_url_str.replace("/pool_info", "")
361
+
362
+ return GetPoolInfoResult(pool_info=response, new_pool_url=new_pool_url)
363
+ else:
364
+ self.handle_failed_pool_response(
365
+ pool_config.p2_singleton_puzzle_hash,
366
+ f"Error in GET /pool_info {pool_config.pool_url}, {resp.status}",
367
+ )
368
+
369
+ except Exception as e:
370
+ self.handle_failed_pool_response(
371
+ pool_config.p2_singleton_puzzle_hash, f"Exception in GET /pool_info {pool_config.pool_url}, {e}"
372
+ )
373
+
374
+ return None
375
+
376
+ async def _pool_get_farmer(
377
+ self, pool_config: PoolWalletConfig, authentication_token_timeout: uint8, authentication_sk: PrivateKey
378
+ ) -> Optional[Dict[str, Any]]:
379
+ authentication_token = get_current_authentication_token(authentication_token_timeout)
380
+ message: bytes32 = std_hash(
381
+ AuthenticationPayload(
382
+ "get_farmer", pool_config.launcher_id, pool_config.target_puzzle_hash, authentication_token
383
+ )
384
+ )
385
+ signature: G2Element = AugSchemeMPL.sign(authentication_sk, message)
386
+ get_farmer_params: dict[str, Union[str, int]] = {
387
+ "launcher_id": pool_config.launcher_id.hex(),
388
+ "authentication_token": authentication_token,
389
+ "signature": bytes(signature).hex(),
390
+ }
391
+ try:
392
+ async with aiohttp.ClientSession(trust_env=True) as session:
393
+ async with session.get(
394
+ f"{pool_config.pool_url}/farmer",
395
+ params=get_farmer_params,
396
+ ssl=ssl_context_for_root(get_mozilla_ca_crt(), log=self.log),
397
+ ) as resp:
398
+ if resp.ok:
399
+ response: Dict[str, Any] = json.loads(await resp.text())
400
+ log_level = logging.INFO
401
+ if "error_code" in response:
402
+ log_level = logging.WARNING
403
+ increment_pool_stats(
404
+ self.pool_state,
405
+ pool_config.p2_singleton_puzzle_hash,
406
+ "pool_errors",
407
+ time.time(),
408
+ value=response,
409
+ )
410
+ self.log.log(log_level, f"GET /farmer response: {response}")
411
+ return response
412
+ else:
413
+ self.handle_failed_pool_response(
414
+ pool_config.p2_singleton_puzzle_hash,
415
+ f"Error in GET /farmer {pool_config.pool_url}, {resp.status}",
416
+ )
417
+ except Exception as e:
418
+ self.handle_failed_pool_response(
419
+ pool_config.p2_singleton_puzzle_hash, f"Exception in GET /farmer {pool_config.pool_url}, {e}"
420
+ )
421
+ return None
422
+
423
+ async def _pool_post_farmer(
424
+ self, pool_config: PoolWalletConfig, authentication_token_timeout: uint8, owner_sk: PrivateKey
425
+ ) -> Optional[Dict[str, Any]]:
426
+ auth_sk: Optional[PrivateKey] = self.get_authentication_sk(pool_config)
427
+ assert auth_sk is not None
428
+ post_farmer_payload: PostFarmerPayload = PostFarmerPayload(
429
+ pool_config.launcher_id,
430
+ get_current_authentication_token(authentication_token_timeout),
431
+ auth_sk.get_g1(),
432
+ pool_config.payout_instructions,
433
+ None,
434
+ )
435
+ assert owner_sk.get_g1() == pool_config.owner_public_key
436
+ signature: G2Element = AugSchemeMPL.sign(owner_sk, post_farmer_payload.get_hash())
437
+ post_farmer_request = PostFarmerRequest(post_farmer_payload, signature)
438
+ self.log.debug(f"POST /farmer request {post_farmer_request}")
439
+ try:
440
+ async with aiohttp.ClientSession() as session:
441
+ async with session.post(
442
+ f"{pool_config.pool_url}/farmer",
443
+ json=post_farmer_request.to_json_dict(),
444
+ ssl=ssl_context_for_root(get_mozilla_ca_crt(), log=self.log),
445
+ ) as resp:
446
+ if resp.ok:
447
+ response: Dict[str, Any] = json.loads(await resp.text())
448
+ log_level = logging.INFO
449
+ if "error_code" in response:
450
+ log_level = logging.WARNING
451
+ increment_pool_stats(
452
+ self.pool_state,
453
+ pool_config.p2_singleton_puzzle_hash,
454
+ "pool_errors",
455
+ time.time(),
456
+ value=response,
457
+ )
458
+ self.log.log(log_level, f"POST /farmer response: {response}")
459
+ return response
460
+ else:
461
+ self.handle_failed_pool_response(
462
+ pool_config.p2_singleton_puzzle_hash,
463
+ f"Error in POST /farmer {pool_config.pool_url}, {resp.status}",
464
+ )
465
+ except Exception as e:
466
+ self.handle_failed_pool_response(
467
+ pool_config.p2_singleton_puzzle_hash, f"Exception in POST /farmer {pool_config.pool_url}, {e}"
468
+ )
469
+ return None
470
+
471
+ async def _pool_put_farmer(
472
+ self, pool_config: PoolWalletConfig, authentication_token_timeout: uint8, owner_sk: PrivateKey
473
+ ) -> None:
474
+ auth_sk: Optional[PrivateKey] = self.get_authentication_sk(pool_config)
475
+ assert auth_sk is not None
476
+ put_farmer_payload: PutFarmerPayload = PutFarmerPayload(
477
+ pool_config.launcher_id,
478
+ get_current_authentication_token(authentication_token_timeout),
479
+ auth_sk.get_g1(),
480
+ pool_config.payout_instructions,
481
+ None,
482
+ )
483
+ assert owner_sk.get_g1() == pool_config.owner_public_key
484
+ signature: G2Element = AugSchemeMPL.sign(owner_sk, put_farmer_payload.get_hash())
485
+ put_farmer_request = PutFarmerRequest(put_farmer_payload, signature)
486
+ self.log.debug(f"PUT /farmer request {put_farmer_request}")
487
+ try:
488
+ async with aiohttp.ClientSession() as session:
489
+ async with session.put(
490
+ f"{pool_config.pool_url}/farmer",
491
+ json=put_farmer_request.to_json_dict(),
492
+ ssl=ssl_context_for_root(get_mozilla_ca_crt(), log=self.log),
493
+ ) as resp:
494
+ if resp.ok:
495
+ response: Dict[str, Any] = json.loads(await resp.text())
496
+ log_level = logging.INFO
497
+ if "error_code" in response:
498
+ log_level = logging.WARNING
499
+ increment_pool_stats(
500
+ self.pool_state,
501
+ pool_config.p2_singleton_puzzle_hash,
502
+ "pool_errors",
503
+ time.time(),
504
+ value=response,
505
+ )
506
+ self.log.log(log_level, f"PUT /farmer response: {response}")
507
+ else:
508
+ self.handle_failed_pool_response(
509
+ pool_config.p2_singleton_puzzle_hash,
510
+ f"Error in PUT /farmer {pool_config.pool_url}, {resp.status}",
511
+ )
512
+ except Exception as e:
513
+ self.handle_failed_pool_response(
514
+ pool_config.p2_singleton_puzzle_hash, f"Exception in PUT /farmer {pool_config.pool_url}, {e}"
515
+ )
516
+
517
+ def get_authentication_sk(self, pool_config: PoolWalletConfig) -> Optional[PrivateKey]:
518
+ if pool_config.p2_singleton_puzzle_hash in self.authentication_keys:
519
+ return self.authentication_keys[pool_config.p2_singleton_puzzle_hash]
520
+ auth_sk: Optional[PrivateKey] = find_authentication_sk(self.all_root_sks, pool_config.owner_public_key)
521
+ if auth_sk is not None:
522
+ self.authentication_keys[pool_config.p2_singleton_puzzle_hash] = auth_sk
523
+ return auth_sk
524
+
525
+ async def update_pool_state(self) -> None:
526
+ config = load_config(self._root_path, "config.yaml")
527
+
528
+ pool_config_list: List[PoolWalletConfig] = load_pool_config(self._root_path)
529
+ for pool_config in pool_config_list:
530
+ p2_singleton_puzzle_hash = pool_config.p2_singleton_puzzle_hash
531
+
532
+ try:
533
+ authentication_sk: Optional[PrivateKey] = self.get_authentication_sk(pool_config)
534
+
535
+ if authentication_sk is None:
536
+ self.log.error(f"Could not find authentication sk for {p2_singleton_puzzle_hash}")
537
+ continue
538
+
539
+ if p2_singleton_puzzle_hash not in self.pool_state:
540
+ self.pool_state[p2_singleton_puzzle_hash] = {
541
+ "p2_singleton_puzzle_hash": p2_singleton_puzzle_hash.hex(),
542
+ "points_found_since_start": 0,
543
+ "points_found_24h": [],
544
+ "points_acknowledged_since_start": 0,
545
+ "points_acknowledged_24h": [],
546
+ "next_farmer_update": 0,
547
+ "next_pool_info_update": 0,
548
+ "current_points": 0,
549
+ "current_difficulty": None,
550
+ "pool_errors_24h": [],
551
+ "valid_partials_since_start": 0,
552
+ "valid_partials_24h": [],
553
+ "invalid_partials_since_start": 0,
554
+ "invalid_partials_24h": [],
555
+ "insufficient_partials_since_start": 0,
556
+ "insufficient_partials_24h": [],
557
+ "stale_partials_since_start": 0,
558
+ "stale_partials_24h": [],
559
+ "missing_partials_since_start": 0,
560
+ "missing_partials_24h": [],
561
+ "authentication_token_timeout": None,
562
+ "plot_count": 0,
563
+ "pool_config": pool_config,
564
+ }
565
+ self.log.info(f"Added pool: {pool_config}")
566
+ else:
567
+ self.pool_state[p2_singleton_puzzle_hash]["pool_config"] = pool_config
568
+
569
+ pool_state = self.pool_state[p2_singleton_puzzle_hash]
570
+
571
+ # Skip state update when self pooling
572
+ if pool_config.pool_url == "":
573
+ continue
574
+
575
+ enforce_https = config["full_node"]["selected_network"] == "mainnet"
576
+ if enforce_https and not pool_config.pool_url.startswith("https://"):
577
+ self.log.error(f"Pool URLs must be HTTPS on mainnet {pool_config.pool_url}")
578
+ continue
579
+
580
+ # TODO: Improve error handling below, inform about unexpected failures
581
+ if time.time() >= pool_state["next_pool_info_update"]:
582
+ pool_state["next_pool_info_update"] = time.time() + UPDATE_POOL_INFO_INTERVAL
583
+ # Makes a GET request to the pool to get the updated information
584
+ pool_info_result = await self._pool_get_pool_info(pool_config)
585
+ if pool_info_result is not None and "error_code" not in pool_info_result.pool_info:
586
+ pool_info = pool_info_result.pool_info
587
+ pool_state["authentication_token_timeout"] = pool_info["authentication_token_timeout"]
588
+ # Only update the first time from GET /pool_info, gets updated from GET /farmer later
589
+ if pool_state["current_difficulty"] is None:
590
+ pool_state["current_difficulty"] = pool_info["minimum_difficulty"]
591
+ else:
592
+ pool_state["next_pool_info_update"] = time.time() + UPDATE_POOL_INFO_FAILURE_RETRY_INTERVAL
593
+
594
+ if pool_info_result is not None and pool_info_result.new_pool_url is not None:
595
+ update_pool_url(self._root_path, pool_config, pool_info_result.new_pool_url)
596
+
597
+ if time.time() >= pool_state["next_farmer_update"]:
598
+ pool_state["next_farmer_update"] = time.time() + UPDATE_POOL_FARMER_INFO_INTERVAL
599
+ authentication_token_timeout = pool_state["authentication_token_timeout"]
600
+
601
+ async def update_pool_farmer_info() -> Tuple[Optional[GetFarmerResponse], Optional[PoolErrorCode]]:
602
+ # Run a GET /farmer to see if the farmer is already known by the pool
603
+ response = await self._pool_get_farmer(
604
+ pool_config, authentication_token_timeout, authentication_sk
605
+ )
606
+ farmer_response: Optional[GetFarmerResponse] = None
607
+ error_code_response: Optional[PoolErrorCode] = None
608
+ if response is not None:
609
+ if "error_code" not in response:
610
+ farmer_response = GetFarmerResponse.from_json_dict(response)
611
+ if farmer_response is not None:
612
+ pool_state["current_difficulty"] = farmer_response.current_difficulty
613
+ pool_state["current_points"] = farmer_response.current_points
614
+ else:
615
+ try:
616
+ error_code_response = PoolErrorCode(response["error_code"])
617
+ except ValueError:
618
+ self.log.error(
619
+ f"Invalid error code received from the pool: {response['error_code']}"
620
+ )
621
+
622
+ return farmer_response, error_code_response
623
+
624
+ if authentication_token_timeout is not None:
625
+ farmer_info, error_code = await update_pool_farmer_info()
626
+ if error_code == PoolErrorCode.FARMER_NOT_KNOWN:
627
+ # Make the farmer known on the pool with a POST /farmer
628
+ owner_sk_and_index = find_owner_sk(self.all_root_sks, pool_config.owner_public_key)
629
+ assert owner_sk_and_index is not None
630
+ post_response = await self._pool_post_farmer(
631
+ pool_config, authentication_token_timeout, owner_sk_and_index[0]
632
+ )
633
+ if post_response is not None and "error_code" not in post_response:
634
+ self.log.info(
635
+ f"Welcome message from {pool_config.pool_url}: "
636
+ f"{post_response['welcome_message']}"
637
+ )
638
+ # Now we should be able to update the local farmer info
639
+ farmer_info, farmer_is_known = await update_pool_farmer_info()
640
+ if farmer_info is None and not farmer_is_known:
641
+ self.log.error("Failed to update farmer info after POST /farmer.")
642
+
643
+ # Update the farmer information on the pool if the payout instructions changed or if the
644
+ # signature is invalid (latter to make sure the pool has the correct authentication public key).
645
+ payout_instructions_update_required: bool = (
646
+ farmer_info is not None
647
+ and pool_config.payout_instructions.lower() != farmer_info.payout_instructions.lower()
648
+ )
649
+ if payout_instructions_update_required or error_code == PoolErrorCode.INVALID_SIGNATURE:
650
+ owner_sk_and_index = find_owner_sk(self.all_root_sks, pool_config.owner_public_key)
651
+ assert owner_sk_and_index is not None
652
+ await self._pool_put_farmer(
653
+ pool_config, authentication_token_timeout, owner_sk_and_index[0]
654
+ )
655
+ else:
656
+ self.log.warning(
657
+ f"No pool specific authentication_token_timeout has been set for {p2_singleton_puzzle_hash}"
658
+ f", check communication with the pool."
659
+ )
660
+
661
+ except Exception as e:
662
+ tb = traceback.format_exc()
663
+ self.log.error(f"Exception in update_pool_state for {pool_config.pool_url}, {e} {tb}")
664
+
665
+ def get_public_keys(self) -> List[G1Element]:
666
+ return [child_sk.get_g1() for child_sk in self._private_keys]
667
+
668
+ def get_private_keys(self) -> List[PrivateKey]:
669
+ return self._private_keys
670
+
671
+ async def get_reward_targets(self, search_for_private_key: bool, max_ph_to_search: int = 500) -> Dict[str, Any]:
672
+ if search_for_private_key:
673
+ all_sks = await self.get_all_private_keys()
674
+ have_farmer_sk, have_pool_sk = False, False
675
+ search_addresses: List[bytes32] = [self.farmer_target, self.pool_target]
676
+ for sk, _ in all_sks:
677
+ found_addresses: Set[bytes32] = match_address_to_sk(sk, search_addresses, max_ph_to_search)
678
+
679
+ if not have_farmer_sk and self.farmer_target in found_addresses:
680
+ search_addresses.remove(self.farmer_target)
681
+ have_farmer_sk = True
682
+
683
+ if not have_pool_sk and self.pool_target in found_addresses:
684
+ search_addresses.remove(self.pool_target)
685
+ have_pool_sk = True
686
+
687
+ if have_farmer_sk and have_pool_sk:
688
+ break
689
+
690
+ return {
691
+ "farmer_target": self.farmer_target_encoded,
692
+ "pool_target": self.pool_target_encoded,
693
+ "have_farmer_sk": have_farmer_sk,
694
+ "have_pool_sk": have_pool_sk,
695
+ }
696
+ return {
697
+ "farmer_target": self.farmer_target_encoded,
698
+ "pool_target": self.pool_target_encoded,
699
+ }
700
+
701
+ def set_reward_targets(self, farmer_target_encoded: Optional[str], pool_target_encoded: Optional[str]) -> None:
702
+ with lock_and_load_config(self._root_path, "config.yaml") as config:
703
+ if farmer_target_encoded is not None:
704
+ self.farmer_target_encoded = farmer_target_encoded
705
+ self.farmer_target = decode_puzzle_hash(farmer_target_encoded)
706
+ config["farmer"]["xch_target_address"] = farmer_target_encoded
707
+ if pool_target_encoded is not None:
708
+ self.pool_target_encoded = pool_target_encoded
709
+ self.pool_target = decode_puzzle_hash(pool_target_encoded)
710
+ config["pool"]["xch_target_address"] = pool_target_encoded
711
+ save_config(self._root_path, "config.yaml", config)
712
+
713
+ async def set_payout_instructions(self, launcher_id: bytes32, payout_instructions: str) -> None:
714
+ for p2_singleton_puzzle_hash, pool_state_dict in self.pool_state.items():
715
+ if launcher_id == pool_state_dict["pool_config"].launcher_id:
716
+ with lock_and_load_config(self._root_path, "config.yaml") as config:
717
+ new_list = []
718
+ pool_list = config["pool"].get("pool_list", [])
719
+ if pool_list is not None:
720
+ for list_element in pool_list:
721
+ if hexstr_to_bytes(list_element["launcher_id"]) == bytes(launcher_id):
722
+ list_element["payout_instructions"] = payout_instructions
723
+ new_list.append(list_element)
724
+
725
+ config["pool"]["pool_list"] = new_list
726
+ save_config(self._root_path, "config.yaml", config)
727
+ # Force a GET /farmer which triggers the PUT /farmer if it detects the changed instructions
728
+ pool_state_dict["next_farmer_update"] = 0
729
+ return
730
+
731
+ self.log.warning(f"Launcher id: {launcher_id} not found")
732
+
733
+ async def generate_login_link(self, launcher_id: bytes32) -> Optional[str]:
734
+ for pool_state in self.pool_state.values():
735
+ pool_config: PoolWalletConfig = pool_state["pool_config"]
736
+ if pool_config.launcher_id != launcher_id:
737
+ continue
738
+
739
+ authentication_sk: Optional[PrivateKey] = self.get_authentication_sk(pool_config)
740
+ if authentication_sk is None:
741
+ self.log.error(f"Could not find authentication sk for {pool_config.p2_singleton_puzzle_hash}")
742
+ continue
743
+ authentication_token_timeout = pool_state["authentication_token_timeout"]
744
+ if authentication_token_timeout is None:
745
+ self.log.error(
746
+ f"No pool specific authentication_token_timeout has been set for"
747
+ f"{pool_config.p2_singleton_puzzle_hash}, check communication with the pool."
748
+ )
749
+ return None
750
+
751
+ authentication_token = get_current_authentication_token(authentication_token_timeout)
752
+ message: bytes32 = std_hash(
753
+ AuthenticationPayload(
754
+ "get_login", pool_config.launcher_id, pool_config.target_puzzle_hash, authentication_token
755
+ )
756
+ )
757
+ signature: G2Element = AugSchemeMPL.sign(authentication_sk, message)
758
+ return (
759
+ pool_config.pool_url
760
+ + f"/login?launcher_id={launcher_id.hex()}&authentication_token={authentication_token}"
761
+ f"&signature={bytes(signature).hex()}"
762
+ )
763
+
764
+ return None
765
+
766
+ async def get_harvesters(self, counts_only: bool = False) -> Dict[str, Any]:
767
+ harvesters: List[Dict[str, Any]] = []
768
+ for connection in self.server.get_connections(NodeType.HARVESTER):
769
+ self.log.debug(f"get_harvesters host: {connection.peer_info.host}, node_id: {connection.peer_node_id}")
770
+ receiver = self.plot_sync_receivers.get(connection.peer_node_id)
771
+ if receiver is not None:
772
+ harvesters.append(receiver.to_dict(counts_only))
773
+ else:
774
+ self.log.debug(
775
+ f"get_harvesters invalid peer: {connection.peer_info.host}, node_id: {connection.peer_node_id}"
776
+ )
777
+
778
+ return {"harvesters": harvesters}
779
+
780
+ def get_receiver(self, node_id: bytes32) -> Receiver:
781
+ receiver: Optional[Receiver] = self.plot_sync_receivers.get(node_id)
782
+ if receiver is None:
783
+ raise KeyError(f"Receiver missing for {node_id}")
784
+ return receiver
785
+
786
+ def check_missing_signage_points(
787
+ self, timestamp: uint64, new_signage_point: farmer_protocol.NewSignagePoint
788
+ ) -> Optional[Tuple[uint64, uint32]]:
789
+ if self.prev_signage_point is None:
790
+ self.prev_signage_point = (timestamp, new_signage_point)
791
+ return None
792
+
793
+ prev_time, prev_sp = self.prev_signage_point
794
+ self.prev_signage_point = (timestamp, new_signage_point)
795
+
796
+ if prev_sp.challenge_hash == new_signage_point.challenge_hash:
797
+ missing_sps = new_signage_point.signage_point_index - prev_sp.signage_point_index - 1
798
+ if missing_sps > 0:
799
+ return timestamp, uint32(missing_sps)
800
+ return None
801
+
802
+ actual_sp_interval_seconds = float(timestamp - prev_time)
803
+ if actual_sp_interval_seconds <= 0:
804
+ return None
805
+
806
+ expected_sp_interval_seconds = self.constants.SUB_SLOT_TIME_TARGET / self.constants.NUM_SPS_SUB_SLOT
807
+ allowance = 1.6 # Should be chosen from the range (1 <= allowance < 2)
808
+ if actual_sp_interval_seconds < expected_sp_interval_seconds * allowance:
809
+ return None
810
+
811
+ skipped_sps = uint32(floor(actual_sp_interval_seconds / expected_sp_interval_seconds))
812
+ return timestamp, skipped_sps
813
+
814
+ async def _periodically_update_pool_state_task(self) -> None:
815
+ time_slept = 0
816
+ config_path: Path = config_path_for_filename(self._root_path, "config.yaml")
817
+ while not self._shut_down:
818
+ # Every time the config file changes, read it to check the pool state
819
+ stat_info = config_path.stat()
820
+ if stat_info.st_mtime > self.last_config_access_time:
821
+ # If we detect the config file changed, refresh private keys first just in case
822
+ self.all_root_sks = [sk for sk, _ in await self.get_all_private_keys()]
823
+ self.last_config_access_time = stat_info.st_mtime
824
+ await self.update_pool_state()
825
+ time_slept = 0
826
+ elif time_slept > 60:
827
+ await self.update_pool_state()
828
+ time_slept = 0
829
+ time_slept += 1
830
+ await asyncio.sleep(1)
831
+
832
+ async def _periodically_clear_cache_and_refresh_task(self) -> None:
833
+ time_slept = 0
834
+ refresh_slept = 0
835
+ while not self._shut_down:
836
+ try:
837
+ if time_slept > self.constants.SUB_SLOT_TIME_TARGET:
838
+ now = time.time()
839
+ removed_keys: List[bytes32] = []
840
+ for key, add_time in self.cache_add_time.items():
841
+ if now - float(add_time) > self.constants.SUB_SLOT_TIME_TARGET * 3:
842
+ self.sps.pop(key, None)
843
+ self.proofs_of_space.pop(key, None)
844
+ self.quality_str_to_identifiers.pop(key, None)
845
+ self.number_of_responses.pop(key, None)
846
+ removed_keys.append(key)
847
+ for key in removed_keys:
848
+ self.cache_add_time.pop(key, None)
849
+ time_slept = 0
850
+ log.debug(
851
+ f"Cleared farmer cache. Num sps: {len(self.sps)} {len(self.proofs_of_space)} "
852
+ f"{len(self.quality_str_to_identifiers)} {len(self.number_of_responses)}"
853
+ )
854
+ time_slept += 1
855
+ refresh_slept += 1
856
+ # Periodically refresh GUI to show the correct download/upload rate.
857
+ if refresh_slept >= 30:
858
+ self.state_changed("add_connection", {})
859
+ refresh_slept = 0
860
+
861
+ except Exception:
862
+ log.error(f"_periodically_clear_cache_and_refresh_task failed: {traceback.format_exc()}")
863
+
864
+ await asyncio.sleep(1)
865
+
866
+ def notify_farmer_reward_taken_by_harvester_as_fee(
867
+ self, sp: farmer_protocol.NewSignagePoint, proof_of_space: harvester_protocol.NewProofOfSpace
868
+ ) -> None:
869
+ """
870
+ Apply a fee quality convention (see CHIP-22: https://github.com/Chia-Network/chips/pull/88)
871
+ given the proof and signage point. This will be tested against the fee threshold reported
872
+ by the harvester (if any), and logged.
873
+ """
874
+ assert proof_of_space.farmer_reward_address_override is not None
875
+
876
+ challenge_str = str(sp.challenge_hash)
877
+
878
+ ph_prefix = self.config["network_overrides"]["config"][self.config["selected_network"]]["address_prefix"]
879
+ farmer_reward_puzzle_hash = encode_puzzle_hash(proof_of_space.farmer_reward_address_override, ph_prefix)
880
+
881
+ self.log.info(
882
+ f"Farmer reward for challenge '{challenge_str}' "
883
+ + f"taken by harvester for reward address '{farmer_reward_puzzle_hash}'"
884
+ )
885
+
886
+ fee_quality = calculate_harvester_fee_quality(proof_of_space.proof.proof, sp.challenge_hash)
887
+ fee_quality_rate = float(fee_quality) / float(0xFFFFFFFF) * 100.0
888
+
889
+ if proof_of_space.fee_info is not None:
890
+ fee_threshold = proof_of_space.fee_info.applied_fee_threshold
891
+ fee_threshold_rate = float(fee_threshold) / float(0xFFFFFFFF) * 100.0
892
+
893
+ if fee_quality <= fee_threshold:
894
+ self.log.info(
895
+ f"Fee threshold passed for challenge '{challenge_str}': "
896
+ + f"{fee_quality_rate:.3f}%/{fee_threshold_rate:.3f}% ({fee_quality}/{fee_threshold})"
897
+ )
898
+ else:
899
+ self.log.warning(
900
+ f"Invalid fee threshold for challenge '{challenge_str}': "
901
+ + f"{fee_quality_rate:.3f}%/{fee_threshold_rate:.3f}% ({fee_quality}/{fee_threshold})"
902
+ )
903
+ self.log.warning(
904
+ "Harvester illegitimately took a fee reward that "
905
+ + "did not belong to it or it incorrectly applied the fee convention."
906
+ )
907
+ else:
908
+ self.log.warning(
909
+ "Harvester illegitimately took reward by failing to provide its fee rate "
910
+ + f"for challenge '{challenge_str}'. "
911
+ + f"Fee quality was {fee_quality_rate:.3f}% ({fee_quality} or 0x{fee_quality:08x})"
912
+ )
913
+
914
+
915
+ def calculate_harvester_fee_quality(proof: bytes, challenge: bytes32) -> uint32:
916
+ """
917
+ This calculates the 'fee quality' given a convention between farmers and third party harvesters.
918
+ See CHIP-22: https://github.com/Chia-Network/chips/pull/88
919
+ """
920
+ return uint32(int.from_bytes(std_hash(proof + challenge)[32 - 4 :], byteorder="big", signed=False))