chia-blockchain 2.5.1rc1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- chia/__init__.py +10 -0
- chia/__main__.py +5 -0
- chia/_tests/README.md +53 -0
- chia/_tests/__init__.py +0 -0
- chia/_tests/blockchain/__init__.py +0 -0
- chia/_tests/blockchain/blockchain_test_utils.py +195 -0
- chia/_tests/blockchain/config.py +4 -0
- chia/_tests/blockchain/test_augmented_chain.py +145 -0
- chia/_tests/blockchain/test_blockchain.py +4202 -0
- chia/_tests/blockchain/test_blockchain_transactions.py +1031 -0
- chia/_tests/blockchain/test_build_chains.py +59 -0
- chia/_tests/blockchain/test_get_block_generator.py +72 -0
- chia/_tests/blockchain/test_lookup_fork_chain.py +194 -0
- chia/_tests/build-init-files.py +92 -0
- chia/_tests/build-job-matrix.py +204 -0
- chia/_tests/check_pytest_monitor_output.py +34 -0
- chia/_tests/check_sql_statements.py +72 -0
- chia/_tests/chia-start-sim +42 -0
- chia/_tests/clvm/__init__.py +0 -0
- chia/_tests/clvm/benchmark_costs.py +23 -0
- chia/_tests/clvm/coin_store.py +149 -0
- chia/_tests/clvm/test_chialisp_deserialization.py +101 -0
- chia/_tests/clvm/test_clvm_step.py +37 -0
- chia/_tests/clvm/test_condition_codes.py +13 -0
- chia/_tests/clvm/test_curry_and_treehash.py +55 -0
- chia/_tests/clvm/test_message_conditions.py +184 -0
- chia/_tests/clvm/test_program.py +150 -0
- chia/_tests/clvm/test_puzzle_compression.py +143 -0
- chia/_tests/clvm/test_puzzle_drivers.py +45 -0
- chia/_tests/clvm/test_puzzles.py +242 -0
- chia/_tests/clvm/test_singletons.py +540 -0
- chia/_tests/clvm/test_spend_sim.py +181 -0
- chia/_tests/cmds/__init__.py +0 -0
- chia/_tests/cmds/cmd_test_utils.py +469 -0
- chia/_tests/cmds/config.py +3 -0
- chia/_tests/cmds/conftest.py +23 -0
- chia/_tests/cmds/test_click_types.py +200 -0
- chia/_tests/cmds/test_cmd_framework.py +620 -0
- chia/_tests/cmds/test_cmds_util.py +97 -0
- chia/_tests/cmds/test_daemon.py +92 -0
- chia/_tests/cmds/test_dev_gh.py +131 -0
- chia/_tests/cmds/test_farm_cmd.py +66 -0
- chia/_tests/cmds/test_show.py +116 -0
- chia/_tests/cmds/test_sim.py +207 -0
- chia/_tests/cmds/test_timelock_args.py +75 -0
- chia/_tests/cmds/test_tx_config_args.py +154 -0
- chia/_tests/cmds/testing_classes.py +59 -0
- chia/_tests/cmds/wallet/__init__.py +0 -0
- chia/_tests/cmds/wallet/test_consts.py +47 -0
- chia/_tests/cmds/wallet/test_dao.py +565 -0
- chia/_tests/cmds/wallet/test_did.py +403 -0
- chia/_tests/cmds/wallet/test_nft.py +471 -0
- chia/_tests/cmds/wallet/test_notifications.py +124 -0
- chia/_tests/cmds/wallet/test_offer.toffer +1 -0
- chia/_tests/cmds/wallet/test_tx_decorators.py +27 -0
- chia/_tests/cmds/wallet/test_vcs.py +400 -0
- chia/_tests/cmds/wallet/test_wallet.py +1125 -0
- chia/_tests/cmds/wallet/test_wallet_check.py +109 -0
- chia/_tests/conftest.py +1419 -0
- chia/_tests/connection_utils.py +125 -0
- chia/_tests/core/__init__.py +0 -0
- chia/_tests/core/cmds/__init__.py +0 -0
- chia/_tests/core/cmds/test_beta.py +382 -0
- chia/_tests/core/cmds/test_keys.py +1734 -0
- chia/_tests/core/cmds/test_wallet.py +126 -0
- chia/_tests/core/config.py +3 -0
- chia/_tests/core/consensus/__init__.py +0 -0
- chia/_tests/core/consensus/test_block_creation.py +54 -0
- chia/_tests/core/consensus/test_pot_iterations.py +117 -0
- chia/_tests/core/custom_types/__init__.py +0 -0
- chia/_tests/core/custom_types/test_coin.py +107 -0
- chia/_tests/core/custom_types/test_proof_of_space.py +144 -0
- chia/_tests/core/custom_types/test_spend_bundle.py +70 -0
- chia/_tests/core/daemon/__init__.py +0 -0
- chia/_tests/core/daemon/config.py +4 -0
- chia/_tests/core/daemon/test_daemon.py +2128 -0
- chia/_tests/core/daemon/test_daemon_register.py +109 -0
- chia/_tests/core/daemon/test_keychain_proxy.py +101 -0
- chia/_tests/core/data_layer/__init__.py +0 -0
- chia/_tests/core/data_layer/config.py +5 -0
- chia/_tests/core/data_layer/conftest.py +106 -0
- chia/_tests/core/data_layer/test_data_cli.py +56 -0
- chia/_tests/core/data_layer/test_data_layer.py +83 -0
- chia/_tests/core/data_layer/test_data_layer_util.py +218 -0
- chia/_tests/core/data_layer/test_data_rpc.py +3847 -0
- chia/_tests/core/data_layer/test_data_store.py +2424 -0
- chia/_tests/core/data_layer/test_data_store_schema.py +381 -0
- chia/_tests/core/data_layer/test_plugin.py +91 -0
- chia/_tests/core/data_layer/util.py +233 -0
- chia/_tests/core/farmer/__init__.py +0 -0
- chia/_tests/core/farmer/config.py +3 -0
- chia/_tests/core/farmer/test_farmer_api.py +103 -0
- chia/_tests/core/full_node/__init__.py +0 -0
- chia/_tests/core/full_node/config.py +4 -0
- chia/_tests/core/full_node/dos/__init__.py +0 -0
- chia/_tests/core/full_node/dos/config.py +3 -0
- chia/_tests/core/full_node/full_sync/__init__.py +0 -0
- chia/_tests/core/full_node/full_sync/config.py +4 -0
- chia/_tests/core/full_node/full_sync/test_full_sync.py +443 -0
- chia/_tests/core/full_node/ram_db.py +27 -0
- chia/_tests/core/full_node/stores/__init__.py +0 -0
- chia/_tests/core/full_node/stores/config.py +4 -0
- chia/_tests/core/full_node/stores/test_block_store.py +590 -0
- chia/_tests/core/full_node/stores/test_coin_store.py +897 -0
- chia/_tests/core/full_node/stores/test_full_node_store.py +1219 -0
- chia/_tests/core/full_node/stores/test_hint_store.py +229 -0
- chia/_tests/core/full_node/stores/test_sync_store.py +135 -0
- chia/_tests/core/full_node/test_address_manager.py +588 -0
- chia/_tests/core/full_node/test_block_height_map.py +556 -0
- chia/_tests/core/full_node/test_conditions.py +556 -0
- chia/_tests/core/full_node/test_full_node.py +2700 -0
- chia/_tests/core/full_node/test_generator_tools.py +82 -0
- chia/_tests/core/full_node/test_hint_management.py +104 -0
- chia/_tests/core/full_node/test_node_load.py +34 -0
- chia/_tests/core/full_node/test_performance.py +179 -0
- chia/_tests/core/full_node/test_subscriptions.py +492 -0
- chia/_tests/core/full_node/test_transactions.py +203 -0
- chia/_tests/core/full_node/test_tx_processing_queue.py +155 -0
- chia/_tests/core/large_block.py +2388 -0
- chia/_tests/core/make_block_generator.py +70 -0
- chia/_tests/core/mempool/__init__.py +0 -0
- chia/_tests/core/mempool/config.py +4 -0
- chia/_tests/core/mempool/test_mempool.py +3255 -0
- chia/_tests/core/mempool/test_mempool_fee_estimator.py +104 -0
- chia/_tests/core/mempool/test_mempool_fee_protocol.py +55 -0
- chia/_tests/core/mempool/test_mempool_item_queries.py +190 -0
- chia/_tests/core/mempool/test_mempool_manager.py +2084 -0
- chia/_tests/core/mempool/test_mempool_performance.py +64 -0
- chia/_tests/core/mempool/test_singleton_fast_forward.py +567 -0
- chia/_tests/core/node_height.py +28 -0
- chia/_tests/core/server/__init__.py +0 -0
- chia/_tests/core/server/config.py +3 -0
- chia/_tests/core/server/flood.py +84 -0
- chia/_tests/core/server/serve.py +135 -0
- chia/_tests/core/server/test_api_protocol.py +21 -0
- chia/_tests/core/server/test_capabilities.py +66 -0
- chia/_tests/core/server/test_dos.py +319 -0
- chia/_tests/core/server/test_event_loop.py +109 -0
- chia/_tests/core/server/test_loop.py +294 -0
- chia/_tests/core/server/test_node_discovery.py +73 -0
- chia/_tests/core/server/test_rate_limits.py +482 -0
- chia/_tests/core/server/test_server.py +226 -0
- chia/_tests/core/server/test_upnp.py +8 -0
- chia/_tests/core/services/__init__.py +0 -0
- chia/_tests/core/services/config.py +3 -0
- chia/_tests/core/services/test_services.py +188 -0
- chia/_tests/core/ssl/__init__.py +0 -0
- chia/_tests/core/ssl/config.py +3 -0
- chia/_tests/core/ssl/test_ssl.py +202 -0
- chia/_tests/core/test_coins.py +33 -0
- chia/_tests/core/test_cost_calculation.py +313 -0
- chia/_tests/core/test_crawler.py +175 -0
- chia/_tests/core/test_crawler_rpc.py +53 -0
- chia/_tests/core/test_daemon_rpc.py +24 -0
- chia/_tests/core/test_db_conversion.py +130 -0
- chia/_tests/core/test_db_validation.py +162 -0
- chia/_tests/core/test_farmer_harvester_rpc.py +505 -0
- chia/_tests/core/test_filter.py +35 -0
- chia/_tests/core/test_full_node_rpc.py +768 -0
- chia/_tests/core/test_merkle_set.py +343 -0
- chia/_tests/core/test_program.py +47 -0
- chia/_tests/core/test_rpc_util.py +86 -0
- chia/_tests/core/test_seeder.py +420 -0
- chia/_tests/core/test_setproctitle.py +13 -0
- chia/_tests/core/util/__init__.py +0 -0
- chia/_tests/core/util/config.py +4 -0
- chia/_tests/core/util/test_block_cache.py +44 -0
- chia/_tests/core/util/test_cached_bls.py +57 -0
- chia/_tests/core/util/test_config.py +337 -0
- chia/_tests/core/util/test_file_keyring_synchronization.py +105 -0
- chia/_tests/core/util/test_files.py +391 -0
- chia/_tests/core/util/test_jsonify.py +146 -0
- chia/_tests/core/util/test_keychain.py +522 -0
- chia/_tests/core/util/test_keyring_wrapper.py +491 -0
- chia/_tests/core/util/test_lockfile.py +380 -0
- chia/_tests/core/util/test_log_exceptions.py +187 -0
- chia/_tests/core/util/test_lru_cache.py +56 -0
- chia/_tests/core/util/test_significant_bits.py +40 -0
- chia/_tests/core/util/test_streamable.py +883 -0
- chia/_tests/db/__init__.py +0 -0
- chia/_tests/db/test_db_wrapper.py +566 -0
- chia/_tests/environments/__init__.py +0 -0
- chia/_tests/environments/common.py +35 -0
- chia/_tests/environments/full_node.py +47 -0
- chia/_tests/environments/wallet.py +429 -0
- chia/_tests/ether.py +19 -0
- chia/_tests/farmer_harvester/__init__.py +0 -0
- chia/_tests/farmer_harvester/config.py +3 -0
- chia/_tests/farmer_harvester/test_farmer.py +1264 -0
- chia/_tests/farmer_harvester/test_farmer_harvester.py +292 -0
- chia/_tests/farmer_harvester/test_filter_prefix_bits.py +131 -0
- chia/_tests/farmer_harvester/test_third_party_harvesters.py +528 -0
- chia/_tests/farmer_harvester/test_third_party_harvesters_data.json +29 -0
- chia/_tests/fee_estimation/__init__.py +0 -0
- chia/_tests/fee_estimation/config.py +3 -0
- chia/_tests/fee_estimation/test_fee_estimation_integration.py +262 -0
- chia/_tests/fee_estimation/test_fee_estimation_rpc.py +287 -0
- chia/_tests/fee_estimation/test_fee_estimation_unit_tests.py +144 -0
- chia/_tests/fee_estimation/test_mempoolitem_height_added.py +146 -0
- chia/_tests/generator/__init__.py +0 -0
- chia/_tests/generator/puzzles/__init__.py +0 -0
- chia/_tests/generator/puzzles/test_generator_deserialize.clsp +3 -0
- chia/_tests/generator/puzzles/test_generator_deserialize.clsp.hex +1 -0
- chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp +19 -0
- chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp.hex +1 -0
- chia/_tests/generator/test_compression.py +201 -0
- chia/_tests/generator/test_generator_types.py +44 -0
- chia/_tests/generator/test_rom.py +180 -0
- chia/_tests/plot_sync/__init__.py +0 -0
- chia/_tests/plot_sync/config.py +3 -0
- chia/_tests/plot_sync/test_delta.py +101 -0
- chia/_tests/plot_sync/test_plot_sync.py +618 -0
- chia/_tests/plot_sync/test_receiver.py +451 -0
- chia/_tests/plot_sync/test_sender.py +116 -0
- chia/_tests/plot_sync/test_sync_simulated.py +451 -0
- chia/_tests/plot_sync/util.py +68 -0
- chia/_tests/plotting/__init__.py +0 -0
- chia/_tests/plotting/config.py +3 -0
- chia/_tests/plotting/test_plot_manager.py +781 -0
- chia/_tests/plotting/util.py +12 -0
- chia/_tests/pools/__init__.py +0 -0
- chia/_tests/pools/config.py +5 -0
- chia/_tests/pools/test_pool_cli_parsing.py +128 -0
- chia/_tests/pools/test_pool_cmdline.py +1001 -0
- chia/_tests/pools/test_pool_config.py +42 -0
- chia/_tests/pools/test_pool_puzzles_lifecycle.py +397 -0
- chia/_tests/pools/test_pool_rpc.py +1123 -0
- chia/_tests/pools/test_pool_wallet.py +205 -0
- chia/_tests/pools/test_wallet_pool_store.py +161 -0
- chia/_tests/process_junit.py +348 -0
- chia/_tests/rpc/__init__.py +0 -0
- chia/_tests/rpc/test_rpc_client.py +138 -0
- chia/_tests/rpc/test_rpc_server.py +183 -0
- chia/_tests/simulation/__init__.py +0 -0
- chia/_tests/simulation/config.py +6 -0
- chia/_tests/simulation/test_simulation.py +501 -0
- chia/_tests/simulation/test_simulator.py +232 -0
- chia/_tests/simulation/test_start_simulator.py +107 -0
- chia/_tests/testconfig.py +13 -0
- chia/_tests/timelord/__init__.py +0 -0
- chia/_tests/timelord/config.py +3 -0
- chia/_tests/timelord/test_new_peak.py +437 -0
- chia/_tests/timelord/test_timelord.py +11 -0
- chia/_tests/tools/1315537.json +170 -0
- chia/_tests/tools/1315544.json +160 -0
- chia/_tests/tools/1315630.json +150 -0
- chia/_tests/tools/300000.json +105 -0
- chia/_tests/tools/442734.json +140 -0
- chia/_tests/tools/466212.json +130 -0
- chia/_tests/tools/__init__.py +0 -0
- chia/_tests/tools/config.py +5 -0
- chia/_tests/tools/test-blockchain-db.sqlite +0 -0
- chia/_tests/tools/test_full_sync.py +30 -0
- chia/_tests/tools/test_legacy_keyring.py +82 -0
- chia/_tests/tools/test_run_block.py +128 -0
- chia/_tests/tools/test_virtual_project.py +591 -0
- chia/_tests/util/__init__.py +0 -0
- chia/_tests/util/benchmark_cost.py +170 -0
- chia/_tests/util/benchmarks.py +153 -0
- chia/_tests/util/bip39_test_vectors.json +148 -0
- chia/_tests/util/blockchain.py +134 -0
- chia/_tests/util/blockchain_mock.py +132 -0
- chia/_tests/util/build_network_protocol_files.py +302 -0
- chia/_tests/util/clvm_generator.bin +0 -0
- chia/_tests/util/config.py +3 -0
- chia/_tests/util/constants.py +20 -0
- chia/_tests/util/db_connection.py +37 -0
- chia/_tests/util/full_sync.py +253 -0
- chia/_tests/util/gen_ssl_certs.py +114 -0
- chia/_tests/util/generator_tools_testing.py +45 -0
- chia/_tests/util/get_name_puzzle_conditions.py +52 -0
- chia/_tests/util/key_tool.py +36 -0
- chia/_tests/util/misc.py +675 -0
- chia/_tests/util/network_protocol_data.py +1072 -0
- chia/_tests/util/protocol_messages_bytes-v1.0 +0 -0
- chia/_tests/util/protocol_messages_json.py +2701 -0
- chia/_tests/util/rpc.py +26 -0
- chia/_tests/util/run_block.py +163 -0
- chia/_tests/util/setup_nodes.py +481 -0
- chia/_tests/util/spend_sim.py +492 -0
- chia/_tests/util/split_managers.py +102 -0
- chia/_tests/util/temp_file.py +14 -0
- chia/_tests/util/test_action_scope.py +144 -0
- chia/_tests/util/test_async_pool.py +366 -0
- chia/_tests/util/test_build_job_matrix.py +42 -0
- chia/_tests/util/test_build_network_protocol_files.py +7 -0
- chia/_tests/util/test_chia_version.py +50 -0
- chia/_tests/util/test_collection.py +11 -0
- chia/_tests/util/test_condition_tools.py +229 -0
- chia/_tests/util/test_config.py +426 -0
- chia/_tests/util/test_dump_keyring.py +60 -0
- chia/_tests/util/test_errors.py +10 -0
- chia/_tests/util/test_full_block_utils.py +279 -0
- chia/_tests/util/test_installed.py +20 -0
- chia/_tests/util/test_limited_semaphore.py +53 -0
- chia/_tests/util/test_logging_filter.py +42 -0
- chia/_tests/util/test_misc.py +445 -0
- chia/_tests/util/test_network.py +73 -0
- chia/_tests/util/test_network_protocol_files.py +578 -0
- chia/_tests/util/test_network_protocol_json.py +267 -0
- chia/_tests/util/test_network_protocol_test.py +256 -0
- chia/_tests/util/test_paginator.py +71 -0
- chia/_tests/util/test_pprint.py +17 -0
- chia/_tests/util/test_priority_mutex.py +488 -0
- chia/_tests/util/test_recursive_replace.py +116 -0
- chia/_tests/util/test_replace_str_to_bytes.py +137 -0
- chia/_tests/util/test_service_groups.py +15 -0
- chia/_tests/util/test_ssl_check.py +31 -0
- chia/_tests/util/test_testnet_overrides.py +19 -0
- chia/_tests/util/test_tests_misc.py +38 -0
- chia/_tests/util/test_timing.py +37 -0
- chia/_tests/util/test_trusted_peer.py +51 -0
- chia/_tests/util/time_out_assert.py +191 -0
- chia/_tests/wallet/__init__.py +0 -0
- chia/_tests/wallet/cat_wallet/__init__.py +0 -0
- chia/_tests/wallet/cat_wallet/config.py +4 -0
- chia/_tests/wallet/cat_wallet/test_cat_lifecycle.py +468 -0
- chia/_tests/wallet/cat_wallet/test_cat_outer_puzzle.py +69 -0
- chia/_tests/wallet/cat_wallet/test_cat_wallet.py +1826 -0
- chia/_tests/wallet/cat_wallet/test_offer_lifecycle.py +291 -0
- chia/_tests/wallet/cat_wallet/test_trades.py +2600 -0
- chia/_tests/wallet/clawback/__init__.py +0 -0
- chia/_tests/wallet/clawback/config.py +3 -0
- chia/_tests/wallet/clawback/test_clawback_decorator.py +78 -0
- chia/_tests/wallet/clawback/test_clawback_lifecycle.py +292 -0
- chia/_tests/wallet/clawback/test_clawback_metadata.py +50 -0
- chia/_tests/wallet/config.py +4 -0
- chia/_tests/wallet/conftest.py +278 -0
- chia/_tests/wallet/dao_wallet/__init__.py +0 -0
- chia/_tests/wallet/dao_wallet/config.py +3 -0
- chia/_tests/wallet/dao_wallet/test_dao_clvm.py +1330 -0
- chia/_tests/wallet/dao_wallet/test_dao_wallets.py +3488 -0
- chia/_tests/wallet/db_wallet/__init__.py +0 -0
- chia/_tests/wallet/db_wallet/config.py +3 -0
- chia/_tests/wallet/db_wallet/test_db_graftroot.py +141 -0
- chia/_tests/wallet/db_wallet/test_dl_offers.py +491 -0
- chia/_tests/wallet/db_wallet/test_dl_wallet.py +823 -0
- chia/_tests/wallet/did_wallet/__init__.py +0 -0
- chia/_tests/wallet/did_wallet/config.py +4 -0
- chia/_tests/wallet/did_wallet/test_did.py +2284 -0
- chia/_tests/wallet/nft_wallet/__init__.py +0 -0
- chia/_tests/wallet/nft_wallet/config.py +4 -0
- chia/_tests/wallet/nft_wallet/test_nft_1_offers.py +1493 -0
- chia/_tests/wallet/nft_wallet/test_nft_bulk_mint.py +1024 -0
- chia/_tests/wallet/nft_wallet/test_nft_lifecycle.py +375 -0
- chia/_tests/wallet/nft_wallet/test_nft_offers.py +1209 -0
- chia/_tests/wallet/nft_wallet/test_nft_puzzles.py +172 -0
- chia/_tests/wallet/nft_wallet/test_nft_wallet.py +2584 -0
- chia/_tests/wallet/nft_wallet/test_ownership_outer_puzzle.py +70 -0
- chia/_tests/wallet/rpc/__init__.py +0 -0
- chia/_tests/wallet/rpc/config.py +4 -0
- chia/_tests/wallet/rpc/test_dl_wallet_rpc.py +285 -0
- chia/_tests/wallet/rpc/test_wallet_rpc.py +3153 -0
- chia/_tests/wallet/simple_sync/__init__.py +0 -0
- chia/_tests/wallet/simple_sync/config.py +3 -0
- chia/_tests/wallet/simple_sync/test_simple_sync_protocol.py +718 -0
- chia/_tests/wallet/sync/__init__.py +0 -0
- chia/_tests/wallet/sync/config.py +4 -0
- chia/_tests/wallet/sync/test_wallet_sync.py +1692 -0
- chia/_tests/wallet/test_address_type.py +189 -0
- chia/_tests/wallet/test_bech32m.py +45 -0
- chia/_tests/wallet/test_clvm_streamable.py +244 -0
- chia/_tests/wallet/test_coin_management.py +354 -0
- chia/_tests/wallet/test_coin_selection.py +588 -0
- chia/_tests/wallet/test_conditions.py +400 -0
- chia/_tests/wallet/test_debug_spend_bundle.py +218 -0
- chia/_tests/wallet/test_new_wallet_protocol.py +1174 -0
- chia/_tests/wallet/test_nft_store.py +192 -0
- chia/_tests/wallet/test_notifications.py +196 -0
- chia/_tests/wallet/test_offer_parsing_performance.py +48 -0
- chia/_tests/wallet/test_puzzle_store.py +132 -0
- chia/_tests/wallet/test_sign_coin_spends.py +159 -0
- chia/_tests/wallet/test_signer_protocol.py +947 -0
- chia/_tests/wallet/test_singleton.py +122 -0
- chia/_tests/wallet/test_singleton_lifecycle_fast.py +772 -0
- chia/_tests/wallet/test_singleton_store.py +152 -0
- chia/_tests/wallet/test_taproot.py +19 -0
- chia/_tests/wallet/test_transaction_store.py +945 -0
- chia/_tests/wallet/test_util.py +185 -0
- chia/_tests/wallet/test_wallet.py +2139 -0
- chia/_tests/wallet/test_wallet_action_scope.py +85 -0
- chia/_tests/wallet/test_wallet_blockchain.py +111 -0
- chia/_tests/wallet/test_wallet_coin_store.py +1002 -0
- chia/_tests/wallet/test_wallet_interested_store.py +43 -0
- chia/_tests/wallet/test_wallet_key_val_store.py +40 -0
- chia/_tests/wallet/test_wallet_node.py +780 -0
- chia/_tests/wallet/test_wallet_retry.py +95 -0
- chia/_tests/wallet/test_wallet_state_manager.py +259 -0
- chia/_tests/wallet/test_wallet_test_framework.py +275 -0
- chia/_tests/wallet/test_wallet_trade_store.py +218 -0
- chia/_tests/wallet/test_wallet_user_store.py +34 -0
- chia/_tests/wallet/test_wallet_utils.py +156 -0
- chia/_tests/wallet/vc_wallet/__init__.py +0 -0
- chia/_tests/wallet/vc_wallet/config.py +3 -0
- chia/_tests/wallet/vc_wallet/test_cr_outer_puzzle.py +70 -0
- chia/_tests/wallet/vc_wallet/test_vc_lifecycle.py +883 -0
- chia/_tests/wallet/vc_wallet/test_vc_wallet.py +830 -0
- chia/_tests/wallet/wallet_block_tools.py +327 -0
- chia/_tests/weight_proof/__init__.py +0 -0
- chia/_tests/weight_proof/config.py +3 -0
- chia/_tests/weight_proof/test_weight_proof.py +528 -0
- chia/apis.py +19 -0
- chia/clvm/__init__.py +0 -0
- chia/cmds/__init__.py +0 -0
- chia/cmds/beta.py +184 -0
- chia/cmds/beta_funcs.py +137 -0
- chia/cmds/check_wallet_db.py +420 -0
- chia/cmds/chia.py +151 -0
- chia/cmds/cmd_classes.py +323 -0
- chia/cmds/cmd_helpers.py +242 -0
- chia/cmds/cmds_util.py +488 -0
- chia/cmds/coin_funcs.py +275 -0
- chia/cmds/coins.py +182 -0
- chia/cmds/completion.py +49 -0
- chia/cmds/configure.py +332 -0
- chia/cmds/dao.py +1064 -0
- chia/cmds/dao_funcs.py +598 -0
- chia/cmds/data.py +708 -0
- chia/cmds/data_funcs.py +385 -0
- chia/cmds/db.py +87 -0
- chia/cmds/db_backup_func.py +77 -0
- chia/cmds/db_upgrade_func.py +452 -0
- chia/cmds/db_validate_func.py +184 -0
- chia/cmds/dev.py +18 -0
- chia/cmds/farm.py +100 -0
- chia/cmds/farm_funcs.py +200 -0
- chia/cmds/gh.py +275 -0
- chia/cmds/init.py +63 -0
- chia/cmds/init_funcs.py +367 -0
- chia/cmds/installers.py +131 -0
- chia/cmds/keys.py +527 -0
- chia/cmds/keys_funcs.py +863 -0
- chia/cmds/netspace.py +50 -0
- chia/cmds/netspace_funcs.py +54 -0
- chia/cmds/options.py +32 -0
- chia/cmds/param_types.py +238 -0
- chia/cmds/passphrase.py +131 -0
- chia/cmds/passphrase_funcs.py +292 -0
- chia/cmds/peer.py +51 -0
- chia/cmds/peer_funcs.py +129 -0
- chia/cmds/plotnft.py +260 -0
- chia/cmds/plotnft_funcs.py +405 -0
- chia/cmds/plots.py +230 -0
- chia/cmds/plotters.py +18 -0
- chia/cmds/rpc.py +208 -0
- chia/cmds/show.py +72 -0
- chia/cmds/show_funcs.py +215 -0
- chia/cmds/signer.py +296 -0
- chia/cmds/sim.py +225 -0
- chia/cmds/sim_funcs.py +509 -0
- chia/cmds/start.py +24 -0
- chia/cmds/start_funcs.py +109 -0
- chia/cmds/stop.py +62 -0
- chia/cmds/units.py +9 -0
- chia/cmds/wallet.py +1901 -0
- chia/cmds/wallet_funcs.py +1874 -0
- chia/consensus/__init__.py +0 -0
- chia/consensus/block_body_validation.py +562 -0
- chia/consensus/block_creation.py +546 -0
- chia/consensus/block_header_validation.py +1059 -0
- chia/consensus/block_record.py +31 -0
- chia/consensus/block_rewards.py +53 -0
- chia/consensus/blockchain.py +1087 -0
- chia/consensus/blockchain_interface.py +56 -0
- chia/consensus/coinbase.py +30 -0
- chia/consensus/condition_costs.py +9 -0
- chia/consensus/constants.py +49 -0
- chia/consensus/cost_calculator.py +15 -0
- chia/consensus/default_constants.py +89 -0
- chia/consensus/deficit.py +55 -0
- chia/consensus/difficulty_adjustment.py +412 -0
- chia/consensus/find_fork_point.py +111 -0
- chia/consensus/full_block_to_block_record.py +167 -0
- chia/consensus/get_block_challenge.py +106 -0
- chia/consensus/get_block_generator.py +27 -0
- chia/consensus/make_sub_epoch_summary.py +210 -0
- chia/consensus/multiprocess_validation.py +268 -0
- chia/consensus/pos_quality.py +19 -0
- chia/consensus/pot_iterations.py +67 -0
- chia/consensus/puzzles/__init__.py +0 -0
- chia/consensus/puzzles/chialisp_deserialisation.clsp +69 -0
- chia/consensus/puzzles/chialisp_deserialisation.clsp.hex +1 -0
- chia/consensus/puzzles/rom_bootstrap_generator.clsp +37 -0
- chia/consensus/puzzles/rom_bootstrap_generator.clsp.hex +1 -0
- chia/consensus/vdf_info_computation.py +156 -0
- chia/daemon/__init__.py +0 -0
- chia/daemon/client.py +252 -0
- chia/daemon/keychain_proxy.py +502 -0
- chia/daemon/keychain_server.py +365 -0
- chia/daemon/server.py +1606 -0
- chia/daemon/windows_signal.py +56 -0
- chia/data_layer/__init__.py +0 -0
- chia/data_layer/data_layer.py +1291 -0
- chia/data_layer/data_layer_api.py +33 -0
- chia/data_layer/data_layer_errors.py +50 -0
- chia/data_layer/data_layer_server.py +170 -0
- chia/data_layer/data_layer_util.py +985 -0
- chia/data_layer/data_layer_wallet.py +1311 -0
- chia/data_layer/data_store.py +2267 -0
- chia/data_layer/dl_wallet_store.py +407 -0
- chia/data_layer/download_data.py +389 -0
- chia/data_layer/puzzles/__init__.py +0 -0
- chia/data_layer/puzzles/graftroot_dl_offers.clsp +100 -0
- chia/data_layer/puzzles/graftroot_dl_offers.clsp.hex +1 -0
- chia/data_layer/s3_plugin_config.yml +33 -0
- chia/data_layer/s3_plugin_service.py +468 -0
- chia/data_layer/util/__init__.py +0 -0
- chia/data_layer/util/benchmark.py +107 -0
- chia/data_layer/util/plugin.py +40 -0
- chia/farmer/__init__.py +0 -0
- chia/farmer/farmer.py +923 -0
- chia/farmer/farmer_api.py +820 -0
- chia/full_node/__init__.py +0 -0
- chia/full_node/bitcoin_fee_estimator.py +85 -0
- chia/full_node/block_height_map.py +271 -0
- chia/full_node/block_store.py +576 -0
- chia/full_node/bundle_tools.py +19 -0
- chia/full_node/coin_store.py +647 -0
- chia/full_node/fee_estimate.py +54 -0
- chia/full_node/fee_estimate_store.py +24 -0
- chia/full_node/fee_estimation.py +92 -0
- chia/full_node/fee_estimator.py +90 -0
- chia/full_node/fee_estimator_constants.py +38 -0
- chia/full_node/fee_estimator_interface.py +42 -0
- chia/full_node/fee_history.py +25 -0
- chia/full_node/fee_tracker.py +564 -0
- chia/full_node/full_node.py +3327 -0
- chia/full_node/full_node_api.py +2025 -0
- chia/full_node/full_node_store.py +1033 -0
- chia/full_node/hint_management.py +56 -0
- chia/full_node/hint_store.py +93 -0
- chia/full_node/mempool.py +589 -0
- chia/full_node/mempool_check_conditions.py +146 -0
- chia/full_node/mempool_manager.py +853 -0
- chia/full_node/pending_tx_cache.py +112 -0
- chia/full_node/puzzles/__init__.py +0 -0
- chia/full_node/puzzles/block_program_zero.clsp +14 -0
- chia/full_node/puzzles/block_program_zero.clsp.hex +1 -0
- chia/full_node/puzzles/decompress_coin_spend_entry.clsp +5 -0
- chia/full_node/puzzles/decompress_coin_spend_entry.clsp.hex +1 -0
- chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp +7 -0
- chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp.hex +1 -0
- chia/full_node/puzzles/decompress_puzzle.clsp +6 -0
- chia/full_node/puzzles/decompress_puzzle.clsp.hex +1 -0
- chia/full_node/signage_point.py +16 -0
- chia/full_node/subscriptions.py +247 -0
- chia/full_node/sync_store.py +146 -0
- chia/full_node/tx_processing_queue.py +78 -0
- chia/full_node/util/__init__.py +0 -0
- chia/full_node/weight_proof.py +1720 -0
- chia/harvester/__init__.py +0 -0
- chia/harvester/harvester.py +272 -0
- chia/harvester/harvester_api.py +380 -0
- chia/introducer/__init__.py +0 -0
- chia/introducer/introducer.py +122 -0
- chia/introducer/introducer_api.py +70 -0
- chia/legacy/__init__.py +0 -0
- chia/legacy/keyring.py +155 -0
- chia/plot_sync/__init__.py +0 -0
- chia/plot_sync/delta.py +61 -0
- chia/plot_sync/exceptions.py +56 -0
- chia/plot_sync/receiver.py +386 -0
- chia/plot_sync/sender.py +340 -0
- chia/plot_sync/util.py +43 -0
- chia/plotters/__init__.py +0 -0
- chia/plotters/bladebit.py +388 -0
- chia/plotters/chiapos.py +63 -0
- chia/plotters/madmax.py +224 -0
- chia/plotters/plotters.py +577 -0
- chia/plotters/plotters_util.py +133 -0
- chia/plotting/__init__.py +0 -0
- chia/plotting/cache.py +213 -0
- chia/plotting/check_plots.py +283 -0
- chia/plotting/create_plots.py +278 -0
- chia/plotting/manager.py +436 -0
- chia/plotting/util.py +336 -0
- chia/pools/__init__.py +0 -0
- chia/pools/pool_config.py +110 -0
- chia/pools/pool_puzzles.py +459 -0
- chia/pools/pool_wallet.py +933 -0
- chia/pools/pool_wallet_info.py +118 -0
- chia/pools/puzzles/__init__.py +0 -0
- chia/pools/puzzles/pool_member_innerpuz.clsp +70 -0
- chia/pools/puzzles/pool_member_innerpuz.clsp.hex +1 -0
- chia/pools/puzzles/pool_waitingroom_innerpuz.clsp +69 -0
- chia/pools/puzzles/pool_waitingroom_innerpuz.clsp.hex +1 -0
- chia/protocols/__init__.py +0 -0
- chia/protocols/farmer_protocol.py +102 -0
- chia/protocols/full_node_protocol.py +219 -0
- chia/protocols/harvester_protocol.py +216 -0
- chia/protocols/introducer_protocol.py +25 -0
- chia/protocols/pool_protocol.py +177 -0
- chia/protocols/protocol_message_types.py +139 -0
- chia/protocols/protocol_state_machine.py +87 -0
- chia/protocols/protocol_timing.py +8 -0
- chia/protocols/shared_protocol.py +86 -0
- chia/protocols/timelord_protocol.py +93 -0
- chia/protocols/wallet_protocol.py +401 -0
- chia/py.typed +0 -0
- chia/rpc/__init__.py +0 -0
- chia/rpc/crawler_rpc_api.py +80 -0
- chia/rpc/data_layer_rpc_api.py +644 -0
- chia/rpc/data_layer_rpc_client.py +188 -0
- chia/rpc/data_layer_rpc_util.py +58 -0
- chia/rpc/farmer_rpc_api.py +365 -0
- chia/rpc/farmer_rpc_client.py +86 -0
- chia/rpc/full_node_rpc_api.py +959 -0
- chia/rpc/full_node_rpc_client.py +292 -0
- chia/rpc/harvester_rpc_api.py +141 -0
- chia/rpc/harvester_rpc_client.py +54 -0
- chia/rpc/rpc_client.py +164 -0
- chia/rpc/rpc_server.py +521 -0
- chia/rpc/timelord_rpc_api.py +32 -0
- chia/rpc/util.py +93 -0
- chia/rpc/wallet_request_types.py +904 -0
- chia/rpc/wallet_rpc_api.py +4943 -0
- chia/rpc/wallet_rpc_client.py +1814 -0
- chia/seeder/__init__.py +0 -0
- chia/seeder/crawl_store.py +425 -0
- chia/seeder/crawler.py +410 -0
- chia/seeder/crawler_api.py +135 -0
- chia/seeder/dns_server.py +593 -0
- chia/seeder/peer_record.py +146 -0
- chia/seeder/start_crawler.py +92 -0
- chia/server/__init__.py +0 -0
- chia/server/address_manager.py +658 -0
- chia/server/address_manager_store.py +237 -0
- chia/server/api_protocol.py +116 -0
- chia/server/capabilities.py +24 -0
- chia/server/chia_policy.py +346 -0
- chia/server/introducer_peers.py +76 -0
- chia/server/node_discovery.py +714 -0
- chia/server/outbound_message.py +33 -0
- chia/server/rate_limit_numbers.py +214 -0
- chia/server/rate_limits.py +153 -0
- chia/server/server.py +741 -0
- chia/server/signal_handlers.py +120 -0
- chia/server/ssl_context.py +32 -0
- chia/server/start_data_layer.py +151 -0
- chia/server/start_farmer.py +98 -0
- chia/server/start_full_node.py +112 -0
- chia/server/start_harvester.py +93 -0
- chia/server/start_introducer.py +81 -0
- chia/server/start_service.py +316 -0
- chia/server/start_timelord.py +89 -0
- chia/server/start_wallet.py +113 -0
- chia/server/upnp.py +118 -0
- chia/server/ws_connection.py +766 -0
- chia/simulator/__init__.py +0 -0
- chia/simulator/add_blocks_in_batches.py +54 -0
- chia/simulator/block_tools.py +2054 -0
- chia/simulator/full_node_simulator.py +794 -0
- chia/simulator/keyring.py +128 -0
- chia/simulator/setup_services.py +506 -0
- chia/simulator/simulator_constants.py +13 -0
- chia/simulator/simulator_full_node_rpc_api.py +99 -0
- chia/simulator/simulator_full_node_rpc_client.py +60 -0
- chia/simulator/simulator_protocol.py +29 -0
- chia/simulator/simulator_test_tools.py +164 -0
- chia/simulator/socket.py +24 -0
- chia/simulator/ssl_certs.py +114 -0
- chia/simulator/ssl_certs_1.py +697 -0
- chia/simulator/ssl_certs_10.py +697 -0
- chia/simulator/ssl_certs_2.py +697 -0
- chia/simulator/ssl_certs_3.py +697 -0
- chia/simulator/ssl_certs_4.py +697 -0
- chia/simulator/ssl_certs_5.py +697 -0
- chia/simulator/ssl_certs_6.py +697 -0
- chia/simulator/ssl_certs_7.py +697 -0
- chia/simulator/ssl_certs_8.py +697 -0
- chia/simulator/ssl_certs_9.py +697 -0
- chia/simulator/start_simulator.py +143 -0
- chia/simulator/wallet_tools.py +246 -0
- chia/ssl/__init__.py +0 -0
- chia/ssl/chia_ca.crt +19 -0
- chia/ssl/chia_ca.key +28 -0
- chia/ssl/create_ssl.py +249 -0
- chia/ssl/dst_root_ca.pem +20 -0
- chia/timelord/__init__.py +0 -0
- chia/timelord/iters_from_block.py +50 -0
- chia/timelord/timelord.py +1226 -0
- chia/timelord/timelord_api.py +138 -0
- chia/timelord/timelord_launcher.py +190 -0
- chia/timelord/timelord_state.py +244 -0
- chia/timelord/types.py +22 -0
- chia/types/__init__.py +0 -0
- chia/types/aliases.py +35 -0
- chia/types/block_protocol.py +20 -0
- chia/types/blockchain_format/__init__.py +0 -0
- chia/types/blockchain_format/classgroup.py +5 -0
- chia/types/blockchain_format/coin.py +28 -0
- chia/types/blockchain_format/foliage.py +8 -0
- chia/types/blockchain_format/pool_target.py +5 -0
- chia/types/blockchain_format/program.py +269 -0
- chia/types/blockchain_format/proof_of_space.py +135 -0
- chia/types/blockchain_format/reward_chain_block.py +6 -0
- chia/types/blockchain_format/serialized_program.py +5 -0
- chia/types/blockchain_format/sized_bytes.py +11 -0
- chia/types/blockchain_format/slots.py +9 -0
- chia/types/blockchain_format/sub_epoch_summary.py +5 -0
- chia/types/blockchain_format/tree_hash.py +72 -0
- chia/types/blockchain_format/vdf.py +86 -0
- chia/types/clvm_cost.py +13 -0
- chia/types/coin_record.py +43 -0
- chia/types/coin_spend.py +115 -0
- chia/types/condition_opcodes.py +73 -0
- chia/types/condition_with_args.py +16 -0
- chia/types/eligible_coin_spends.py +365 -0
- chia/types/end_of_slot_bundle.py +5 -0
- chia/types/fee_rate.py +38 -0
- chia/types/full_block.py +5 -0
- chia/types/generator_types.py +13 -0
- chia/types/header_block.py +5 -0
- chia/types/internal_mempool_item.py +18 -0
- chia/types/mempool_inclusion_status.py +9 -0
- chia/types/mempool_item.py +85 -0
- chia/types/mempool_submission_status.py +30 -0
- chia/types/mojos.py +7 -0
- chia/types/peer_info.py +64 -0
- chia/types/signing_mode.py +29 -0
- chia/types/spend_bundle.py +30 -0
- chia/types/spend_bundle_conditions.py +7 -0
- chia/types/transaction_queue_entry.py +55 -0
- chia/types/unfinished_block.py +5 -0
- chia/types/unfinished_header_block.py +37 -0
- chia/types/validation_state.py +14 -0
- chia/types/weight_proof.py +49 -0
- chia/util/__init__.py +0 -0
- chia/util/action_scope.py +168 -0
- chia/util/async_pool.py +226 -0
- chia/util/augmented_chain.py +134 -0
- chia/util/batches.py +42 -0
- chia/util/bech32m.py +126 -0
- chia/util/beta_metrics.py +119 -0
- chia/util/block_cache.py +56 -0
- chia/util/byte_types.py +12 -0
- chia/util/check_fork_next_block.py +33 -0
- chia/util/chia_logging.py +144 -0
- chia/util/chia_version.py +33 -0
- chia/util/collection.py +17 -0
- chia/util/condition_tools.py +201 -0
- chia/util/config.py +367 -0
- chia/util/cpu.py +22 -0
- chia/util/db_synchronous.py +23 -0
- chia/util/db_version.py +32 -0
- chia/util/db_wrapper.py +430 -0
- chia/util/default_root.py +27 -0
- chia/util/dump_keyring.py +93 -0
- chia/util/english.txt +2048 -0
- chia/util/errors.py +353 -0
- chia/util/file_keyring.py +469 -0
- chia/util/files.py +97 -0
- chia/util/full_block_utils.py +345 -0
- chia/util/generator_tools.py +72 -0
- chia/util/hash.py +31 -0
- chia/util/initial-config.yaml +694 -0
- chia/util/inline_executor.py +26 -0
- chia/util/ints.py +19 -0
- chia/util/ip_address.py +39 -0
- chia/util/json_util.py +37 -0
- chia/util/keychain.py +676 -0
- chia/util/keyring_wrapper.py +327 -0
- chia/util/limited_semaphore.py +41 -0
- chia/util/lock.py +49 -0
- chia/util/log_exceptions.py +32 -0
- chia/util/logging.py +36 -0
- chia/util/lru_cache.py +31 -0
- chia/util/math.py +20 -0
- chia/util/network.py +182 -0
- chia/util/paginator.py +48 -0
- chia/util/path.py +31 -0
- chia/util/permissions.py +20 -0
- chia/util/prev_transaction_block.py +21 -0
- chia/util/priority_mutex.py +95 -0
- chia/util/profiler.py +197 -0
- chia/util/recursive_replace.py +24 -0
- chia/util/safe_cancel_task.py +16 -0
- chia/util/service_groups.py +47 -0
- chia/util/setproctitle.py +22 -0
- chia/util/significant_bits.py +32 -0
- chia/util/ssl_check.py +213 -0
- chia/util/streamable.py +642 -0
- chia/util/task_referencer.py +59 -0
- chia/util/task_timing.py +382 -0
- chia/util/timing.py +67 -0
- chia/util/vdf_prover.py +30 -0
- chia/util/virtual_project_analysis.py +540 -0
- chia/util/ws_message.py +66 -0
- chia/wallet/__init__.py +0 -0
- chia/wallet/cat_wallet/__init__.py +0 -0
- chia/wallet/cat_wallet/cat_constants.py +75 -0
- chia/wallet/cat_wallet/cat_info.py +47 -0
- chia/wallet/cat_wallet/cat_outer_puzzle.py +120 -0
- chia/wallet/cat_wallet/cat_utils.py +164 -0
- chia/wallet/cat_wallet/cat_wallet.py +855 -0
- chia/wallet/cat_wallet/dao_cat_info.py +28 -0
- chia/wallet/cat_wallet/dao_cat_wallet.py +669 -0
- chia/wallet/cat_wallet/lineage_store.py +74 -0
- chia/wallet/cat_wallet/puzzles/__init__.py +0 -0
- chia/wallet/cat_wallet/puzzles/cat_truths.clib +31 -0
- chia/wallet/cat_wallet/puzzles/cat_v2.clsp +397 -0
- chia/wallet/cat_wallet/puzzles/cat_v2.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/delegated_tail.clsp +25 -0
- chia/wallet/cat_wallet/puzzles/delegated_tail.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp +15 -0
- chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp +26 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp +42 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp +24 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp.hex +1 -0
- chia/wallet/coin_selection.py +188 -0
- chia/wallet/conditions.py +1512 -0
- chia/wallet/dao_wallet/__init__.py +0 -0
- chia/wallet/dao_wallet/dao_info.py +61 -0
- chia/wallet/dao_wallet/dao_utils.py +811 -0
- chia/wallet/dao_wallet/dao_wallet.py +2119 -0
- chia/wallet/db_wallet/__init__.py +0 -0
- chia/wallet/db_wallet/db_wallet_puzzles.py +111 -0
- chia/wallet/derivation_record.py +30 -0
- chia/wallet/derive_keys.py +146 -0
- chia/wallet/did_wallet/__init__.py +0 -0
- chia/wallet/did_wallet/did_info.py +39 -0
- chia/wallet/did_wallet/did_wallet.py +1494 -0
- chia/wallet/did_wallet/did_wallet_puzzles.py +221 -0
- chia/wallet/did_wallet/puzzles/__init__.py +0 -0
- chia/wallet/did_wallet/puzzles/did_innerpuz.clsp +135 -0
- chia/wallet/did_wallet/puzzles/did_innerpuz.clsp.hex +1 -0
- chia/wallet/driver_protocol.py +26 -0
- chia/wallet/key_val_store.py +55 -0
- chia/wallet/lineage_proof.py +58 -0
- chia/wallet/nft_wallet/__init__.py +0 -0
- chia/wallet/nft_wallet/metadata_outer_puzzle.py +92 -0
- chia/wallet/nft_wallet/nft_info.py +120 -0
- chia/wallet/nft_wallet/nft_puzzles.py +305 -0
- chia/wallet/nft_wallet/nft_wallet.py +1687 -0
- chia/wallet/nft_wallet/ownership_outer_puzzle.py +101 -0
- chia/wallet/nft_wallet/puzzles/__init__.py +0 -0
- chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp +6 -0
- chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp +6 -0
- chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp +30 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp +28 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp +100 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp +78 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp +74 -0
- chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp.hex +1 -0
- chia/wallet/nft_wallet/singleton_outer_puzzle.py +101 -0
- chia/wallet/nft_wallet/transfer_program_puzzle.py +82 -0
- chia/wallet/nft_wallet/uncurry_nft.py +217 -0
- chia/wallet/notification_manager.py +117 -0
- chia/wallet/notification_store.py +178 -0
- chia/wallet/outer_puzzles.py +84 -0
- chia/wallet/payment.py +33 -0
- chia/wallet/puzzle_drivers.py +118 -0
- chia/wallet/puzzles/__init__.py +0 -0
- chia/wallet/puzzles/augmented_condition.clsp +13 -0
- chia/wallet/puzzles/augmented_condition.clsp.hex +1 -0
- chia/wallet/puzzles/clawback/__init__.py +0 -0
- chia/wallet/puzzles/clawback/drivers.py +188 -0
- chia/wallet/puzzles/clawback/metadata.py +38 -0
- chia/wallet/puzzles/clawback/puzzle_decorator.py +67 -0
- chia/wallet/puzzles/condition_codes.clib +77 -0
- chia/wallet/puzzles/curry-and-treehash.clib +102 -0
- chia/wallet/puzzles/curry.clib +135 -0
- chia/wallet/puzzles/curry_by_index.clib +16 -0
- chia/wallet/puzzles/dao_cat_eve.clsp +17 -0
- chia/wallet/puzzles/dao_cat_eve.clsp.hex +1 -0
- chia/wallet/puzzles/dao_cat_launcher.clsp +36 -0
- chia/wallet/puzzles/dao_cat_launcher.clsp.hex +1 -0
- chia/wallet/puzzles/dao_finished_state.clsp +35 -0
- chia/wallet/puzzles/dao_finished_state.clsp.hex +1 -0
- chia/wallet/puzzles/dao_finished_state.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_lockup.clsp +288 -0
- chia/wallet/puzzles/dao_lockup.clsp.hex +1 -0
- chia/wallet/puzzles/dao_lockup.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_proposal.clsp +377 -0
- chia/wallet/puzzles/dao_proposal.clsp.hex +1 -0
- chia/wallet/puzzles/dao_proposal.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_proposal_timer.clsp +78 -0
- chia/wallet/puzzles/dao_proposal_timer.clsp.hex +1 -0
- chia/wallet/puzzles/dao_proposal_timer.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_proposal_validator.clsp +87 -0
- chia/wallet/puzzles/dao_proposal_validator.clsp.hex +1 -0
- chia/wallet/puzzles/dao_proposal_validator.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp +240 -0
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex +1 -0
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_treasury.clsp +115 -0
- chia/wallet/puzzles/dao_treasury.clsp.hex +1 -0
- chia/wallet/puzzles/dao_update_proposal.clsp +44 -0
- chia/wallet/puzzles/dao_update_proposal.clsp.hex +1 -0
- chia/wallet/puzzles/deployed_puzzle_hashes.json +67 -0
- chia/wallet/puzzles/json.clib +25 -0
- chia/wallet/puzzles/load_clvm.py +161 -0
- chia/wallet/puzzles/merkle_utils.clib +18 -0
- chia/wallet/puzzles/notification.clsp +7 -0
- chia/wallet/puzzles/notification.clsp.hex +1 -0
- chia/wallet/puzzles/p2_1_of_n.clsp +22 -0
- chia/wallet/puzzles/p2_1_of_n.clsp.hex +1 -0
- chia/wallet/puzzles/p2_conditions.clsp +3 -0
- chia/wallet/puzzles/p2_conditions.clsp.hex +1 -0
- chia/wallet/puzzles/p2_conditions.py +26 -0
- chia/wallet/puzzles/p2_delegated_conditions.clsp +18 -0
- chia/wallet/puzzles/p2_delegated_conditions.clsp.hex +1 -0
- chia/wallet/puzzles/p2_delegated_conditions.py +21 -0
- chia/wallet/puzzles/p2_delegated_puzzle.clsp +19 -0
- chia/wallet/puzzles/p2_delegated_puzzle.clsp.hex +1 -0
- chia/wallet/puzzles/p2_delegated_puzzle.py +34 -0
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp +91 -0
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp.hex +1 -0
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.py +160 -0
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp +108 -0
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp.hex +1 -0
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.py +21 -0
- chia/wallet/puzzles/p2_parent.clsp +19 -0
- chia/wallet/puzzles/p2_parent.clsp.hex +1 -0
- chia/wallet/puzzles/p2_puzzle_hash.clsp +18 -0
- chia/wallet/puzzles/p2_puzzle_hash.clsp.hex +1 -0
- chia/wallet/puzzles/p2_puzzle_hash.py +27 -0
- chia/wallet/puzzles/p2_singleton.clsp +30 -0
- chia/wallet/puzzles/p2_singleton.clsp.hex +1 -0
- chia/wallet/puzzles/p2_singleton_aggregator.clsp +81 -0
- chia/wallet/puzzles/p2_singleton_aggregator.clsp.hex +1 -0
- chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp +50 -0
- chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp.hex +1 -0
- chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp +47 -0
- chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp.hex +1 -0
- chia/wallet/puzzles/puzzle_utils.py +34 -0
- chia/wallet/puzzles/settlement_payments.clsp +49 -0
- chia/wallet/puzzles/settlement_payments.clsp.hex +1 -0
- chia/wallet/puzzles/sha256tree.clib +11 -0
- chia/wallet/puzzles/singleton_launcher.clsp +16 -0
- chia/wallet/puzzles/singleton_launcher.clsp.hex +1 -0
- chia/wallet/puzzles/singleton_top_layer.clsp +177 -0
- chia/wallet/puzzles/singleton_top_layer.clsp.hex +1 -0
- chia/wallet/puzzles/singleton_top_layer.py +296 -0
- chia/wallet/puzzles/singleton_top_layer_v1_1.clsp +107 -0
- chia/wallet/puzzles/singleton_top_layer_v1_1.clsp.hex +1 -0
- chia/wallet/puzzles/singleton_top_layer_v1_1.py +345 -0
- chia/wallet/puzzles/singleton_truths.clib +21 -0
- chia/wallet/puzzles/tails.py +348 -0
- chia/wallet/puzzles/utility_macros.clib +48 -0
- chia/wallet/signer_protocol.py +125 -0
- chia/wallet/singleton.py +106 -0
- chia/wallet/singleton_record.py +30 -0
- chia/wallet/trade_manager.py +1102 -0
- chia/wallet/trade_record.py +67 -0
- chia/wallet/trading/__init__.py +0 -0
- chia/wallet/trading/offer.py +702 -0
- chia/wallet/trading/trade_status.py +13 -0
- chia/wallet/trading/trade_store.py +526 -0
- chia/wallet/transaction_record.py +158 -0
- chia/wallet/transaction_sorting.py +14 -0
- chia/wallet/uncurried_puzzle.py +17 -0
- chia/wallet/util/__init__.py +0 -0
- chia/wallet/util/address_type.py +55 -0
- chia/wallet/util/blind_signer_tl.py +164 -0
- chia/wallet/util/clvm_streamable.py +203 -0
- chia/wallet/util/compute_hints.py +66 -0
- chia/wallet/util/compute_memos.py +43 -0
- chia/wallet/util/curry_and_treehash.py +91 -0
- chia/wallet/util/debug_spend_bundle.py +232 -0
- chia/wallet/util/merkle_tree.py +100 -0
- chia/wallet/util/merkle_utils.py +102 -0
- chia/wallet/util/new_peak_queue.py +82 -0
- chia/wallet/util/notifications.py +12 -0
- chia/wallet/util/peer_request_cache.py +174 -0
- chia/wallet/util/pprint.py +39 -0
- chia/wallet/util/puzzle_compression.py +95 -0
- chia/wallet/util/puzzle_decorator.py +100 -0
- chia/wallet/util/puzzle_decorator_type.py +7 -0
- chia/wallet/util/query_filter.py +59 -0
- chia/wallet/util/transaction_type.py +23 -0
- chia/wallet/util/tx_config.py +158 -0
- chia/wallet/util/wallet_sync_utils.py +351 -0
- chia/wallet/util/wallet_types.py +72 -0
- chia/wallet/vc_wallet/__init__.py +0 -0
- chia/wallet/vc_wallet/cr_cat_drivers.py +664 -0
- chia/wallet/vc_wallet/cr_cat_wallet.py +877 -0
- chia/wallet/vc_wallet/cr_outer_puzzle.py +102 -0
- chia/wallet/vc_wallet/cr_puzzles/__init__.py +0 -0
- chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp +3 -0
- chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp.hex +1 -0
- chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp +304 -0
- chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp.hex +1 -0
- chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp +45 -0
- chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_drivers.py +838 -0
- chia/wallet/vc_wallet/vc_puzzles/__init__.py +0 -0
- chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp +30 -0
- chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp +75 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp +32 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp +80 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp +163 -0
- chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp +16 -0
- chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp +74 -0
- chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp +23 -0
- chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp +64 -0
- chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_store.py +263 -0
- chia/wallet/vc_wallet/vc_wallet.py +638 -0
- chia/wallet/wallet.py +698 -0
- chia/wallet/wallet_action_scope.py +96 -0
- chia/wallet/wallet_blockchain.py +244 -0
- chia/wallet/wallet_coin_record.py +72 -0
- chia/wallet/wallet_coin_store.py +351 -0
- chia/wallet/wallet_info.py +35 -0
- chia/wallet/wallet_interested_store.py +188 -0
- chia/wallet/wallet_nft_store.py +279 -0
- chia/wallet/wallet_node.py +1765 -0
- chia/wallet/wallet_node_api.py +207 -0
- chia/wallet/wallet_pool_store.py +119 -0
- chia/wallet/wallet_protocol.py +90 -0
- chia/wallet/wallet_puzzle_store.py +396 -0
- chia/wallet/wallet_retry_store.py +70 -0
- chia/wallet/wallet_singleton_store.py +259 -0
- chia/wallet/wallet_spend_bundle.py +25 -0
- chia/wallet/wallet_state_manager.py +2819 -0
- chia/wallet/wallet_transaction_store.py +496 -0
- chia/wallet/wallet_user_store.py +110 -0
- chia/wallet/wallet_weight_proof_handler.py +126 -0
- chia_blockchain-2.5.1rc1.dist-info/LICENSE +201 -0
- chia_blockchain-2.5.1rc1.dist-info/METADATA +156 -0
- chia_blockchain-2.5.1rc1.dist-info/RECORD +1042 -0
- chia_blockchain-2.5.1rc1.dist-info/WHEEL +4 -0
- chia_blockchain-2.5.1rc1.dist-info/entry_points.txt +17 -0
- mozilla-ca/cacert.pem +3611 -0
chia/cmds/plotnft.py
ADDED
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from dataclasses import field
|
|
4
|
+
from typing import Optional
|
|
5
|
+
|
|
6
|
+
import click
|
|
7
|
+
|
|
8
|
+
from chia.cmds.cmd_classes import ChiaCliContext, chia_command, option
|
|
9
|
+
from chia.cmds.cmd_helpers import NeedsWalletRPC
|
|
10
|
+
from chia.cmds.param_types import (
|
|
11
|
+
AddressParamType,
|
|
12
|
+
Bytes32ParamType,
|
|
13
|
+
CliAddress,
|
|
14
|
+
TransactionFeeParamType,
|
|
15
|
+
)
|
|
16
|
+
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
17
|
+
from chia.util.errors import CliRpcConnectionError
|
|
18
|
+
from chia.util.ints import uint64
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
@click.group("plotnft", help="Manage your plot NFTs")
|
|
22
|
+
@click.pass_context
|
|
23
|
+
def plotnft_cmd(ctx: click.Context) -> None:
|
|
24
|
+
pass
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
@chia_command(
|
|
28
|
+
group=plotnft_cmd,
|
|
29
|
+
name="show",
|
|
30
|
+
short_help="Show plotnft information",
|
|
31
|
+
help="Show plotnft information",
|
|
32
|
+
)
|
|
33
|
+
class ShowPlotNFTCMD:
|
|
34
|
+
rpc_info: NeedsWalletRPC # provides wallet-rpc-port and fingerprint options
|
|
35
|
+
context: ChiaCliContext = field(default_factory=ChiaCliContext)
|
|
36
|
+
id: Optional[int] = option(
|
|
37
|
+
"-i", "--id", help="ID of the wallet to use", default=None, show_default=True, required=False
|
|
38
|
+
)
|
|
39
|
+
|
|
40
|
+
async def run(self) -> None:
|
|
41
|
+
from chia.cmds.plotnft_funcs import show
|
|
42
|
+
|
|
43
|
+
async with self.rpc_info.wallet_rpc() as wallet_info:
|
|
44
|
+
await show(
|
|
45
|
+
wallet_info=wallet_info,
|
|
46
|
+
root_path=self.context.root_path,
|
|
47
|
+
wallet_id_passed_in=self.id,
|
|
48
|
+
)
|
|
49
|
+
|
|
50
|
+
|
|
51
|
+
@chia_command(
|
|
52
|
+
group=plotnft_cmd,
|
|
53
|
+
name="get_login_link",
|
|
54
|
+
short_help="Create a login link for a pool",
|
|
55
|
+
help="Create a login link for a pool. The farmer must be running. Use 'plotnft show' to get the launcher id.",
|
|
56
|
+
)
|
|
57
|
+
class GetLoginLinkCMD:
|
|
58
|
+
context: ChiaCliContext = field(default_factory=ChiaCliContext)
|
|
59
|
+
launcher_id: bytes32 = option(
|
|
60
|
+
"-l", "--launcher_id", help="Launcher ID of the plotnft", type=Bytes32ParamType(), required=True
|
|
61
|
+
)
|
|
62
|
+
|
|
63
|
+
async def run(self) -> None:
|
|
64
|
+
from chia.cmds.plotnft_funcs import get_login_link
|
|
65
|
+
|
|
66
|
+
await get_login_link(self.launcher_id, root_path=self.context.root_path)
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
# Functions with this mark in this file are not being ported to @tx_out_cmd due to lack of observer key support
|
|
70
|
+
# They will therefore not work with observer-only functionality
|
|
71
|
+
# NOTE: tx_endpoint (This creates wallet transactions and should be parametrized by relevant options)
|
|
72
|
+
@chia_command(
|
|
73
|
+
group=plotnft_cmd,
|
|
74
|
+
name="create",
|
|
75
|
+
short_help="Create a plot NFT",
|
|
76
|
+
help="Create a plot NFT.",
|
|
77
|
+
)
|
|
78
|
+
class CreatePlotNFTCMD:
|
|
79
|
+
rpc_info: NeedsWalletRPC # provides wallet-rpc-port and fingerprint options
|
|
80
|
+
pool_url: Optional[str] = option("-u", "--pool-url", help="HTTPS host:port of the pool to join", required=False)
|
|
81
|
+
state: str = option(
|
|
82
|
+
"-s",
|
|
83
|
+
"--state",
|
|
84
|
+
help="Initial state of Plot NFT: local or pool",
|
|
85
|
+
required=True,
|
|
86
|
+
type=click.Choice(["local", "pool"], case_sensitive=False),
|
|
87
|
+
)
|
|
88
|
+
fee: uint64 = option(
|
|
89
|
+
"-m",
|
|
90
|
+
"--fee",
|
|
91
|
+
help="Set the fees per transaction, in XCH. Fee is used TWICE: once to create the singleton, once for init.",
|
|
92
|
+
type=TransactionFeeParamType(),
|
|
93
|
+
default="0",
|
|
94
|
+
show_default=True,
|
|
95
|
+
required=True,
|
|
96
|
+
)
|
|
97
|
+
dont_prompt: bool = option("-y", "--yes", help="No prompts", is_flag=True)
|
|
98
|
+
|
|
99
|
+
async def run(self) -> None:
|
|
100
|
+
from chia.cmds.plotnft_funcs import create
|
|
101
|
+
|
|
102
|
+
if self.pool_url is not None and self.state == "local":
|
|
103
|
+
raise CliRpcConnectionError(f"A pool url [{self.pool_url}] is not allowed with 'local' state")
|
|
104
|
+
|
|
105
|
+
if self.pool_url in {None, ""} and self.state == "pool":
|
|
106
|
+
raise CliRpcConnectionError("A pool url argument (-u/--pool-url) is required with 'pool' state")
|
|
107
|
+
|
|
108
|
+
async with self.rpc_info.wallet_rpc() as wallet_info:
|
|
109
|
+
await create(
|
|
110
|
+
wallet_info=wallet_info,
|
|
111
|
+
pool_url=self.pool_url,
|
|
112
|
+
state="FARMING_TO_POOL" if self.state == "pool" else "SELF_POOLING",
|
|
113
|
+
fee=self.fee,
|
|
114
|
+
prompt=not self.dont_prompt,
|
|
115
|
+
)
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
# NOTE: tx_endpoint
|
|
119
|
+
@chia_command(
|
|
120
|
+
group=plotnft_cmd,
|
|
121
|
+
name="join",
|
|
122
|
+
short_help="Join a plot NFT to a Pool",
|
|
123
|
+
help="Join a plot NFT to a Pool.",
|
|
124
|
+
)
|
|
125
|
+
class JoinPlotNFTCMD:
|
|
126
|
+
rpc_info: NeedsWalletRPC # provides wallet-rpc-port and fingerprint options
|
|
127
|
+
pool_url: str = option("-u", "--pool-url", help="HTTPS host:port of the pool to join", required=True)
|
|
128
|
+
fee: uint64 = option(
|
|
129
|
+
"-m",
|
|
130
|
+
"--fee",
|
|
131
|
+
help="Set the fees per transaction, in XCH. Fee is used TWICE: once to create the singleton, once for init.",
|
|
132
|
+
type=TransactionFeeParamType(),
|
|
133
|
+
default="0",
|
|
134
|
+
show_default=True,
|
|
135
|
+
required=True,
|
|
136
|
+
)
|
|
137
|
+
dont_prompt: bool = option("-y", "--yes", help="No prompts", is_flag=True)
|
|
138
|
+
id: Optional[int] = option(
|
|
139
|
+
"-i", "--id", help="ID of the wallet to use", default=None, show_default=True, required=False
|
|
140
|
+
)
|
|
141
|
+
|
|
142
|
+
async def run(self) -> None:
|
|
143
|
+
from chia.cmds.plotnft_funcs import join_pool
|
|
144
|
+
|
|
145
|
+
async with self.rpc_info.wallet_rpc() as wallet_info:
|
|
146
|
+
await join_pool(
|
|
147
|
+
wallet_info=wallet_info,
|
|
148
|
+
pool_url=self.pool_url,
|
|
149
|
+
fee=self.fee,
|
|
150
|
+
wallet_id=self.id,
|
|
151
|
+
prompt=not self.dont_prompt,
|
|
152
|
+
)
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
# NOTE: tx_endpoint
|
|
156
|
+
@chia_command(
|
|
157
|
+
group=plotnft_cmd,
|
|
158
|
+
name="leave",
|
|
159
|
+
short_help="Leave a pool and return to self-farming",
|
|
160
|
+
help="Leave a pool and return to self-farming.",
|
|
161
|
+
)
|
|
162
|
+
class LeavePlotNFTCMD:
|
|
163
|
+
rpc_info: NeedsWalletRPC # provides wallet-rpc-port and fingerprint options
|
|
164
|
+
dont_prompt: bool = option("-y", "--yes", help="No prompts", is_flag=True)
|
|
165
|
+
fee: uint64 = option(
|
|
166
|
+
"-m",
|
|
167
|
+
"--fee",
|
|
168
|
+
help="Set the fees per transaction, in XCH. Fee is used TWICE: once to create the singleton, once for init.",
|
|
169
|
+
type=TransactionFeeParamType(),
|
|
170
|
+
default="0",
|
|
171
|
+
show_default=True,
|
|
172
|
+
required=True,
|
|
173
|
+
)
|
|
174
|
+
id: Optional[int] = option(
|
|
175
|
+
"-i", "--id", help="ID of the wallet to use", default=None, show_default=True, required=False
|
|
176
|
+
)
|
|
177
|
+
|
|
178
|
+
async def run(self) -> None:
|
|
179
|
+
from chia.cmds.plotnft_funcs import self_pool
|
|
180
|
+
|
|
181
|
+
async with self.rpc_info.wallet_rpc() as wallet_info:
|
|
182
|
+
await self_pool(
|
|
183
|
+
wallet_info=wallet_info,
|
|
184
|
+
fee=self.fee,
|
|
185
|
+
wallet_id=self.id,
|
|
186
|
+
prompt=not self.dont_prompt,
|
|
187
|
+
)
|
|
188
|
+
|
|
189
|
+
|
|
190
|
+
@chia_command(
|
|
191
|
+
group=plotnft_cmd,
|
|
192
|
+
name="inspect",
|
|
193
|
+
short_help="Get Detailed plotnft information as JSON",
|
|
194
|
+
help="Get Detailed plotnft information as JSON",
|
|
195
|
+
)
|
|
196
|
+
class InspectPlotNFTCMD:
|
|
197
|
+
rpc_info: NeedsWalletRPC # provides wallet-rpc-port and fingerprint options
|
|
198
|
+
id: Optional[int] = option(
|
|
199
|
+
"-i", "--id", help="ID of the wallet to use", default=None, show_default=True, required=False
|
|
200
|
+
)
|
|
201
|
+
|
|
202
|
+
async def run(self) -> None:
|
|
203
|
+
from chia.cmds.plotnft_funcs import inspect_cmd
|
|
204
|
+
|
|
205
|
+
async with self.rpc_info.wallet_rpc() as wallet_info:
|
|
206
|
+
await inspect_cmd(wallet_info=wallet_info, wallet_id=self.id)
|
|
207
|
+
|
|
208
|
+
|
|
209
|
+
# NOTE: tx_endpoint
|
|
210
|
+
@chia_command(
|
|
211
|
+
group=plotnft_cmd,
|
|
212
|
+
name="claim",
|
|
213
|
+
short_help="Claim rewards from a plot NFT",
|
|
214
|
+
help="Claim rewards from a plot NFT",
|
|
215
|
+
)
|
|
216
|
+
class ClaimPlotNFTCMD:
|
|
217
|
+
rpc_info: NeedsWalletRPC # provides wallet-rpc-port and fingerprint options
|
|
218
|
+
id: Optional[int] = option(
|
|
219
|
+
"-i", "--id", help="ID of the wallet to use", default=None, show_default=True, required=False
|
|
220
|
+
)
|
|
221
|
+
fee: uint64 = option(
|
|
222
|
+
"-m",
|
|
223
|
+
"--fee",
|
|
224
|
+
help="Set the fees per transaction, in XCH. Fee is used TWICE: once to create the singleton, once for init.",
|
|
225
|
+
type=TransactionFeeParamType(),
|
|
226
|
+
default="0",
|
|
227
|
+
show_default=True,
|
|
228
|
+
required=True,
|
|
229
|
+
)
|
|
230
|
+
|
|
231
|
+
async def run(self) -> None:
|
|
232
|
+
from chia.cmds.plotnft_funcs import claim_cmd
|
|
233
|
+
|
|
234
|
+
async with self.rpc_info.wallet_rpc() as wallet_info:
|
|
235
|
+
await claim_cmd(
|
|
236
|
+
wallet_info=wallet_info,
|
|
237
|
+
fee=self.fee,
|
|
238
|
+
wallet_id=self.id,
|
|
239
|
+
)
|
|
240
|
+
|
|
241
|
+
|
|
242
|
+
@chia_command(
|
|
243
|
+
group=plotnft_cmd,
|
|
244
|
+
name="change_payout_instructions",
|
|
245
|
+
short_help="Change the payout instructions for a pool.",
|
|
246
|
+
help="Change the payout instructions for a pool. Use 'plotnft show' to get the launcher id.",
|
|
247
|
+
)
|
|
248
|
+
class ChangePayoutInstructionsPlotNFTCMD:
|
|
249
|
+
context: ChiaCliContext = field(default_factory=ChiaCliContext)
|
|
250
|
+
launcher_id: bytes32 = option(
|
|
251
|
+
"-l", "--launcher_id", help="Launcher ID of the plotnft", type=Bytes32ParamType(), required=True
|
|
252
|
+
)
|
|
253
|
+
address: CliAddress = option(
|
|
254
|
+
"-a", "--address", help="New address for payout instructions", type=AddressParamType(), required=True
|
|
255
|
+
)
|
|
256
|
+
|
|
257
|
+
async def run(self) -> None:
|
|
258
|
+
from chia.cmds.plotnft_funcs import change_payout_instructions
|
|
259
|
+
|
|
260
|
+
await change_payout_instructions(self.launcher_id, self.address, root_path=self.context.root_path)
|
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
import asyncio
|
|
4
|
+
import functools
|
|
5
|
+
import json
|
|
6
|
+
import time
|
|
7
|
+
from collections.abc import Awaitable
|
|
8
|
+
from dataclasses import replace
|
|
9
|
+
from pathlib import Path
|
|
10
|
+
from pprint import pprint
|
|
11
|
+
from typing import Any, Callable, Optional
|
|
12
|
+
|
|
13
|
+
import aiohttp
|
|
14
|
+
|
|
15
|
+
from chia.cmds.cmd_helpers import WalletClientInfo
|
|
16
|
+
from chia.cmds.cmds_util import (
|
|
17
|
+
cli_confirm,
|
|
18
|
+
get_any_service_client,
|
|
19
|
+
transaction_status_msg,
|
|
20
|
+
transaction_submitted_msg,
|
|
21
|
+
)
|
|
22
|
+
from chia.cmds.param_types import CliAddress
|
|
23
|
+
from chia.cmds.wallet_funcs import print_balance, wallet_coin_unit
|
|
24
|
+
from chia.pools.pool_config import PoolWalletConfig, load_pool_config, update_pool_config
|
|
25
|
+
from chia.pools.pool_wallet_info import PoolSingletonState, PoolWalletInfo
|
|
26
|
+
from chia.protocols.pool_protocol import POOL_PROTOCOL_VERSION
|
|
27
|
+
from chia.rpc.farmer_rpc_client import FarmerRpcClient
|
|
28
|
+
from chia.rpc.wallet_rpc_client import WalletRpcClient
|
|
29
|
+
from chia.server.server import ssl_context_for_root
|
|
30
|
+
from chia.ssl.create_ssl import get_mozilla_ca_crt
|
|
31
|
+
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
32
|
+
from chia.util.bech32m import encode_puzzle_hash
|
|
33
|
+
from chia.util.default_root import DEFAULT_ROOT_PATH
|
|
34
|
+
from chia.util.errors import CliRpcConnectionError
|
|
35
|
+
from chia.util.ints import uint32, uint64
|
|
36
|
+
from chia.wallet.transaction_record import TransactionRecord
|
|
37
|
+
from chia.wallet.util.address_type import AddressType
|
|
38
|
+
from chia.wallet.util.wallet_types import WalletType
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
async def create_pool_args(pool_url: str) -> dict[str, Any]:
|
|
42
|
+
try:
|
|
43
|
+
async with aiohttp.ClientSession() as session:
|
|
44
|
+
async with session.get(f"{pool_url}/pool_info", ssl=ssl_context_for_root(get_mozilla_ca_crt())) as response:
|
|
45
|
+
if response.ok:
|
|
46
|
+
json_dict: dict[str, Any] = json.loads(await response.text())
|
|
47
|
+
else:
|
|
48
|
+
raise ValueError(f"Response from {pool_url} not OK: {response.status}")
|
|
49
|
+
except Exception as e:
|
|
50
|
+
raise ValueError(f"Error connecting to pool {pool_url}: {e}")
|
|
51
|
+
|
|
52
|
+
if json_dict["relative_lock_height"] > 1000:
|
|
53
|
+
raise ValueError("Relative lock height too high for this pool, cannot join")
|
|
54
|
+
if json_dict["protocol_version"] != POOL_PROTOCOL_VERSION:
|
|
55
|
+
raise ValueError(f"Incorrect version: {json_dict['protocol_version']}, should be {POOL_PROTOCOL_VERSION}")
|
|
56
|
+
|
|
57
|
+
header_msg = f"\n---- Pool parameters fetched from {pool_url} ----"
|
|
58
|
+
print(header_msg)
|
|
59
|
+
pprint(json_dict)
|
|
60
|
+
print("-" * len(header_msg))
|
|
61
|
+
return json_dict
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
async def create(
|
|
65
|
+
wallet_info: WalletClientInfo,
|
|
66
|
+
pool_url: Optional[str],
|
|
67
|
+
state: str,
|
|
68
|
+
fee: uint64,
|
|
69
|
+
*,
|
|
70
|
+
prompt: bool,
|
|
71
|
+
) -> None:
|
|
72
|
+
target_puzzle_hash: Optional[bytes32]
|
|
73
|
+
# Could use initial_pool_state_from_dict to simplify
|
|
74
|
+
if state == "SELF_POOLING":
|
|
75
|
+
pool_url = None
|
|
76
|
+
relative_lock_height = uint32(0)
|
|
77
|
+
target_puzzle_hash = None # wallet will fill this in
|
|
78
|
+
elif state == "FARMING_TO_POOL":
|
|
79
|
+
enforce_https = wallet_info.config["selected_network"] == "mainnet"
|
|
80
|
+
assert pool_url is not None
|
|
81
|
+
if enforce_https and not pool_url.startswith("https://"):
|
|
82
|
+
raise CliRpcConnectionError(f"Pool URLs must be HTTPS on mainnet {pool_url}.")
|
|
83
|
+
json_dict = await create_pool_args(pool_url)
|
|
84
|
+
relative_lock_height = json_dict["relative_lock_height"]
|
|
85
|
+
target_puzzle_hash = bytes32.from_hexstr(json_dict["target_puzzle_hash"])
|
|
86
|
+
else:
|
|
87
|
+
raise ValueError("Plot NFT must be created in SELF_POOLING or FARMING_TO_POOL state.")
|
|
88
|
+
|
|
89
|
+
pool_msg = f" and join pool: {pool_url}" if pool_url else ""
|
|
90
|
+
print(f"Will create a plot NFT{pool_msg}.")
|
|
91
|
+
if prompt:
|
|
92
|
+
cli_confirm("Confirm (y/n): ", "Aborting.")
|
|
93
|
+
|
|
94
|
+
try:
|
|
95
|
+
tx_record: TransactionRecord = await wallet_info.client.create_new_pool_wallet(
|
|
96
|
+
target_puzzle_hash,
|
|
97
|
+
pool_url,
|
|
98
|
+
relative_lock_height,
|
|
99
|
+
"localhost:5000",
|
|
100
|
+
"new",
|
|
101
|
+
state,
|
|
102
|
+
fee,
|
|
103
|
+
)
|
|
104
|
+
start = time.time()
|
|
105
|
+
while time.time() - start < 10:
|
|
106
|
+
await asyncio.sleep(0.1)
|
|
107
|
+
tx = await wallet_info.client.get_transaction(tx_record.name)
|
|
108
|
+
if len(tx.sent_to) > 0:
|
|
109
|
+
print(transaction_submitted_msg(tx))
|
|
110
|
+
print(transaction_status_msg(wallet_info.fingerprint, tx_record.name))
|
|
111
|
+
return None
|
|
112
|
+
except Exception as e:
|
|
113
|
+
raise CliRpcConnectionError(
|
|
114
|
+
f"Error creating plot NFT: {e}\n Please start both farmer and wallet with: chia start -r farmer"
|
|
115
|
+
)
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
async def pprint_pool_wallet_state(
|
|
119
|
+
wallet_client: WalletRpcClient,
|
|
120
|
+
wallet_id: int,
|
|
121
|
+
pool_wallet_info: PoolWalletInfo,
|
|
122
|
+
address_prefix: str,
|
|
123
|
+
pool_state_dict: Optional[dict[str, Any]],
|
|
124
|
+
) -> None:
|
|
125
|
+
print(f"Wallet ID: {wallet_id}")
|
|
126
|
+
if pool_wallet_info.current.state == PoolSingletonState.LEAVING_POOL.value and pool_wallet_info.target is None:
|
|
127
|
+
expected_leave_height = pool_wallet_info.singleton_block_height + pool_wallet_info.current.relative_lock_height
|
|
128
|
+
print(f"Current state: INVALID_STATE. Please leave/join again after block height {expected_leave_height}")
|
|
129
|
+
else:
|
|
130
|
+
print(f"Current state: {PoolSingletonState(pool_wallet_info.current.state).name}")
|
|
131
|
+
print(f"Current state from block height: {pool_wallet_info.singleton_block_height}")
|
|
132
|
+
print(f"Launcher ID: {pool_wallet_info.launcher_id}")
|
|
133
|
+
print(
|
|
134
|
+
"Target address (not for plotting): "
|
|
135
|
+
f"{encode_puzzle_hash(pool_wallet_info.current.target_puzzle_hash, address_prefix)}"
|
|
136
|
+
)
|
|
137
|
+
print(f"Number of plots: {0 if pool_state_dict is None else pool_state_dict['plot_count']}")
|
|
138
|
+
print(f"Owner public key: {pool_wallet_info.current.owner_pubkey}")
|
|
139
|
+
|
|
140
|
+
print(
|
|
141
|
+
f"Pool contract address (use ONLY for plotting - do not send money to this address): "
|
|
142
|
+
f"{encode_puzzle_hash(pool_wallet_info.p2_singleton_puzzle_hash, address_prefix)}"
|
|
143
|
+
)
|
|
144
|
+
if pool_wallet_info.target is not None:
|
|
145
|
+
print(f"Target state: {PoolSingletonState(pool_wallet_info.target.state).name}")
|
|
146
|
+
print(f"Target pool URL: {pool_wallet_info.target.pool_url}")
|
|
147
|
+
if pool_wallet_info.current.state == PoolSingletonState.SELF_POOLING.value:
|
|
148
|
+
balances: dict[str, Any] = await wallet_client.get_wallet_balance(wallet_id)
|
|
149
|
+
balance = balances["confirmed_wallet_balance"]
|
|
150
|
+
typ = WalletType(int(WalletType.POOLING_WALLET))
|
|
151
|
+
address_prefix, scale = wallet_coin_unit(typ, address_prefix)
|
|
152
|
+
print(f"Claimable balance: {print_balance(balance, scale, address_prefix)}")
|
|
153
|
+
if pool_wallet_info.current.state == PoolSingletonState.FARMING_TO_POOL.value:
|
|
154
|
+
print(f"Current pool URL: {pool_wallet_info.current.pool_url}")
|
|
155
|
+
if pool_state_dict is not None:
|
|
156
|
+
print(f"Current difficulty: {pool_state_dict['current_difficulty']}")
|
|
157
|
+
print(f"Points balance: {pool_state_dict['current_points']}")
|
|
158
|
+
points_found_24h = [points for timestamp, points in pool_state_dict["points_found_24h"]]
|
|
159
|
+
points_acknowledged_24h = [points for timestamp, points in pool_state_dict["points_acknowledged_24h"]]
|
|
160
|
+
summed_points_found_24h = sum(points_found_24h)
|
|
161
|
+
summed_points_acknowledged_24h = sum(points_acknowledged_24h)
|
|
162
|
+
if summed_points_found_24h == 0:
|
|
163
|
+
success_pct = 0.0
|
|
164
|
+
else:
|
|
165
|
+
success_pct = summed_points_acknowledged_24h / summed_points_found_24h
|
|
166
|
+
print(f"Points found (24h): {summed_points_found_24h}")
|
|
167
|
+
print(f"Percent Successful Points (24h): {success_pct:.2%}")
|
|
168
|
+
payout_instructions: str = pool_state_dict["pool_config"]["payout_instructions"]
|
|
169
|
+
try:
|
|
170
|
+
payout_address = encode_puzzle_hash(bytes32.fromhex(payout_instructions), address_prefix)
|
|
171
|
+
print(f"Payout instructions (pool will pay to this address): {payout_address}")
|
|
172
|
+
except Exception:
|
|
173
|
+
print(f"Payout instructions (pool will pay you with this): {payout_instructions}")
|
|
174
|
+
print(f"Relative lock height: {pool_wallet_info.current.relative_lock_height} blocks")
|
|
175
|
+
if pool_wallet_info.current.state == PoolSingletonState.LEAVING_POOL.value:
|
|
176
|
+
expected_leave_height = pool_wallet_info.singleton_block_height + pool_wallet_info.current.relative_lock_height
|
|
177
|
+
if pool_wallet_info.target is not None:
|
|
178
|
+
print(f"Expected to leave after block height: {expected_leave_height}")
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
async def pprint_all_pool_wallet_state(
|
|
182
|
+
wallet_client: WalletRpcClient,
|
|
183
|
+
get_wallets_response: list[dict[str, Any]],
|
|
184
|
+
address_prefix: str,
|
|
185
|
+
pool_state_dict: dict[bytes32, dict[str, Any]],
|
|
186
|
+
) -> None:
|
|
187
|
+
print(f"Wallet height: {(await wallet_client.get_height_info()).height}")
|
|
188
|
+
print(f"Sync status: {'Synced' if (await wallet_client.get_sync_status()).synced else 'Not synced'}")
|
|
189
|
+
for wallet_info in get_wallets_response:
|
|
190
|
+
pool_wallet_id = wallet_info["id"]
|
|
191
|
+
typ = WalletType(int(wallet_info["type"]))
|
|
192
|
+
if typ == WalletType.POOLING_WALLET:
|
|
193
|
+
pool_wallet_info, _ = await wallet_client.pw_status(pool_wallet_id)
|
|
194
|
+
await pprint_pool_wallet_state(
|
|
195
|
+
wallet_client,
|
|
196
|
+
pool_wallet_id,
|
|
197
|
+
pool_wallet_info,
|
|
198
|
+
address_prefix,
|
|
199
|
+
pool_state_dict.get(pool_wallet_info.launcher_id),
|
|
200
|
+
)
|
|
201
|
+
print("")
|
|
202
|
+
|
|
203
|
+
|
|
204
|
+
async def show(
|
|
205
|
+
wallet_info: WalletClientInfo,
|
|
206
|
+
root_path: Path,
|
|
207
|
+
wallet_id_passed_in: Optional[int],
|
|
208
|
+
) -> None:
|
|
209
|
+
summaries_response = await wallet_info.client.get_wallets()
|
|
210
|
+
config = wallet_info.config
|
|
211
|
+
address_prefix = config["network_overrides"]["config"][config["selected_network"]]["address_prefix"]
|
|
212
|
+
pool_state_dict: dict[bytes32, dict[str, Any]] = dict()
|
|
213
|
+
if wallet_id_passed_in is not None:
|
|
214
|
+
await wallet_id_lookup_and_check(wallet_info.client, wallet_id_passed_in)
|
|
215
|
+
try:
|
|
216
|
+
async with get_any_service_client(
|
|
217
|
+
client_type=FarmerRpcClient,
|
|
218
|
+
root_path=root_path,
|
|
219
|
+
) as (farmer_client, _):
|
|
220
|
+
pool_state_list = (await farmer_client.get_pool_state())["pool_state"]
|
|
221
|
+
pool_state_dict = {
|
|
222
|
+
bytes32.from_hexstr(pool_state_item["pool_config"]["launcher_id"]): pool_state_item
|
|
223
|
+
for pool_state_item in pool_state_list
|
|
224
|
+
}
|
|
225
|
+
if wallet_id_passed_in is not None:
|
|
226
|
+
pool_wallet_info, _ = await wallet_info.client.pw_status(wallet_id_passed_in)
|
|
227
|
+
await pprint_pool_wallet_state(
|
|
228
|
+
wallet_info.client,
|
|
229
|
+
wallet_id_passed_in,
|
|
230
|
+
pool_wallet_info,
|
|
231
|
+
address_prefix,
|
|
232
|
+
pool_state_dict.get(pool_wallet_info.launcher_id),
|
|
233
|
+
)
|
|
234
|
+
else:
|
|
235
|
+
await pprint_all_pool_wallet_state(
|
|
236
|
+
wallet_info.client, summaries_response, address_prefix, pool_state_dict
|
|
237
|
+
)
|
|
238
|
+
except CliRpcConnectionError: # we want to output this if we can't connect to the farmer
|
|
239
|
+
await pprint_all_pool_wallet_state(wallet_info.client, summaries_response, address_prefix, pool_state_dict)
|
|
240
|
+
|
|
241
|
+
|
|
242
|
+
async def get_login_link(launcher_id: bytes32, root_path: Path) -> None:
|
|
243
|
+
async with get_any_service_client(FarmerRpcClient, root_path=root_path) as (farmer_client, _):
|
|
244
|
+
login_link: Optional[str] = await farmer_client.get_pool_login_link(launcher_id)
|
|
245
|
+
if login_link is None:
|
|
246
|
+
raise CliRpcConnectionError("Was not able to get login link.")
|
|
247
|
+
else:
|
|
248
|
+
print(login_link)
|
|
249
|
+
|
|
250
|
+
|
|
251
|
+
async def submit_tx_with_confirmation(
|
|
252
|
+
message: str,
|
|
253
|
+
prompt: bool,
|
|
254
|
+
func: Callable[[], Awaitable[dict[str, Any]]],
|
|
255
|
+
wallet_client: WalletRpcClient,
|
|
256
|
+
fingerprint: int,
|
|
257
|
+
wallet_id: int,
|
|
258
|
+
) -> None:
|
|
259
|
+
print(message)
|
|
260
|
+
if prompt:
|
|
261
|
+
cli_confirm("Confirm (y/n): ", "Aborting.")
|
|
262
|
+
try:
|
|
263
|
+
result = await func()
|
|
264
|
+
tx_record: TransactionRecord = result["transaction"]
|
|
265
|
+
start = time.time()
|
|
266
|
+
while time.time() - start < 10:
|
|
267
|
+
await asyncio.sleep(0.1)
|
|
268
|
+
tx = await wallet_client.get_transaction(tx_record.name)
|
|
269
|
+
if len(tx.sent_to) > 0:
|
|
270
|
+
print(transaction_submitted_msg(tx))
|
|
271
|
+
print(transaction_status_msg(fingerprint, tx_record.name))
|
|
272
|
+
return None
|
|
273
|
+
except Exception as e:
|
|
274
|
+
print(f"Error performing operation on Plot NFT -f {fingerprint} wallet id: {wallet_id}: {e}")
|
|
275
|
+
|
|
276
|
+
|
|
277
|
+
async def wallet_id_lookup_and_check(wallet_client: WalletRpcClient, wallet_id: Optional[int]) -> int:
|
|
278
|
+
selected_wallet_id: int
|
|
279
|
+
|
|
280
|
+
# absent network errors, this should not fail with an error
|
|
281
|
+
pool_wallets = await wallet_client.get_wallets(wallet_type=WalletType.POOLING_WALLET)
|
|
282
|
+
|
|
283
|
+
if wallet_id is None:
|
|
284
|
+
if len(pool_wallets) == 0:
|
|
285
|
+
raise CliRpcConnectionError(
|
|
286
|
+
"No pool wallet found. Use 'chia plotnft create' to create a new pooling wallet."
|
|
287
|
+
)
|
|
288
|
+
if len(pool_wallets) > 1:
|
|
289
|
+
raise CliRpcConnectionError("More than one pool wallet found. Use -i to specify pool wallet id.")
|
|
290
|
+
selected_wallet_id = pool_wallets[0]["id"]
|
|
291
|
+
else:
|
|
292
|
+
selected_wallet_id = wallet_id
|
|
293
|
+
|
|
294
|
+
if not any(wallet["id"] == selected_wallet_id for wallet in pool_wallets):
|
|
295
|
+
raise CliRpcConnectionError(f"Wallet with id: {selected_wallet_id} is not a pool wallet.")
|
|
296
|
+
|
|
297
|
+
return selected_wallet_id
|
|
298
|
+
|
|
299
|
+
|
|
300
|
+
async def join_pool(
|
|
301
|
+
*,
|
|
302
|
+
wallet_info: WalletClientInfo,
|
|
303
|
+
pool_url: str,
|
|
304
|
+
fee: uint64,
|
|
305
|
+
wallet_id: Optional[int],
|
|
306
|
+
prompt: bool,
|
|
307
|
+
) -> None:
|
|
308
|
+
selected_wallet_id = await wallet_id_lookup_and_check(wallet_info.client, wallet_id)
|
|
309
|
+
|
|
310
|
+
enforce_https = wallet_info.config["selected_network"] == "mainnet"
|
|
311
|
+
|
|
312
|
+
if enforce_https and not pool_url.startswith("https://"):
|
|
313
|
+
raise CliRpcConnectionError(f"Pool URLs must be HTTPS on mainnet {pool_url}.")
|
|
314
|
+
try:
|
|
315
|
+
async with aiohttp.ClientSession() as session:
|
|
316
|
+
async with session.get(f"{pool_url}/pool_info", ssl=ssl_context_for_root(get_mozilla_ca_crt())) as response:
|
|
317
|
+
if response.ok:
|
|
318
|
+
json_dict = json.loads(await response.text())
|
|
319
|
+
else:
|
|
320
|
+
raise CliRpcConnectionError(f"Response not OK: {response.status}")
|
|
321
|
+
except Exception as e:
|
|
322
|
+
raise CliRpcConnectionError(f"Error connecting to pool {pool_url}: {e}")
|
|
323
|
+
|
|
324
|
+
if json_dict["relative_lock_height"] > 1000:
|
|
325
|
+
raise CliRpcConnectionError("Relative lock height too high for this pool, cannot join")
|
|
326
|
+
|
|
327
|
+
if json_dict["protocol_version"] != POOL_PROTOCOL_VERSION:
|
|
328
|
+
raise CliRpcConnectionError(
|
|
329
|
+
f"Incorrect version: {json_dict['protocol_version']}, should be {POOL_PROTOCOL_VERSION}"
|
|
330
|
+
)
|
|
331
|
+
|
|
332
|
+
pprint(json_dict)
|
|
333
|
+
msg = f"\nWill join pool: {pool_url} with Plot NFT {wallet_info.fingerprint}."
|
|
334
|
+
func = functools.partial(
|
|
335
|
+
wallet_info.client.pw_join_pool,
|
|
336
|
+
selected_wallet_id,
|
|
337
|
+
bytes32.from_hexstr(json_dict["target_puzzle_hash"]),
|
|
338
|
+
pool_url,
|
|
339
|
+
json_dict["relative_lock_height"],
|
|
340
|
+
fee,
|
|
341
|
+
)
|
|
342
|
+
|
|
343
|
+
await submit_tx_with_confirmation(
|
|
344
|
+
msg, prompt, func, wallet_info.client, wallet_info.fingerprint, selected_wallet_id
|
|
345
|
+
)
|
|
346
|
+
|
|
347
|
+
|
|
348
|
+
async def self_pool(*, wallet_info: WalletClientInfo, fee: uint64, wallet_id: Optional[int], prompt: bool) -> None:
|
|
349
|
+
selected_wallet_id = await wallet_id_lookup_and_check(wallet_info.client, wallet_id)
|
|
350
|
+
msg = (
|
|
351
|
+
"Will start self-farming with Plot NFT on wallet id "
|
|
352
|
+
f"{selected_wallet_id} fingerprint {wallet_info.fingerprint}."
|
|
353
|
+
)
|
|
354
|
+
func = functools.partial(wallet_info.client.pw_self_pool, selected_wallet_id, fee)
|
|
355
|
+
await submit_tx_with_confirmation(
|
|
356
|
+
msg, prompt, func, wallet_info.client, wallet_info.fingerprint, selected_wallet_id
|
|
357
|
+
)
|
|
358
|
+
|
|
359
|
+
|
|
360
|
+
async def inspect_cmd(wallet_info: WalletClientInfo, wallet_id: Optional[int]) -> None:
|
|
361
|
+
selected_wallet_id = await wallet_id_lookup_and_check(wallet_info.client, wallet_id)
|
|
362
|
+
pool_wallet_info, unconfirmed_transactions = await wallet_info.client.pw_status(selected_wallet_id)
|
|
363
|
+
print(
|
|
364
|
+
json.dumps(
|
|
365
|
+
{
|
|
366
|
+
"pool_wallet_info": pool_wallet_info.to_json_dict(),
|
|
367
|
+
"unconfirmed_transactions": [
|
|
368
|
+
{"sent_to": tx.sent_to, "transaction_id": tx.name.hex()} for tx in unconfirmed_transactions
|
|
369
|
+
],
|
|
370
|
+
}
|
|
371
|
+
)
|
|
372
|
+
)
|
|
373
|
+
|
|
374
|
+
|
|
375
|
+
async def claim_cmd(*, wallet_info: WalletClientInfo, fee: uint64, wallet_id: Optional[int]) -> None:
|
|
376
|
+
selected_wallet_id = await wallet_id_lookup_and_check(wallet_info.client, wallet_id)
|
|
377
|
+
msg = f"\nWill claim rewards for wallet ID: {selected_wallet_id}."
|
|
378
|
+
func = functools.partial(
|
|
379
|
+
wallet_info.client.pw_absorb_rewards,
|
|
380
|
+
selected_wallet_id,
|
|
381
|
+
fee,
|
|
382
|
+
)
|
|
383
|
+
await submit_tx_with_confirmation(msg, False, func, wallet_info.client, wallet_info.fingerprint, selected_wallet_id)
|
|
384
|
+
|
|
385
|
+
|
|
386
|
+
async def change_payout_instructions(launcher_id: bytes32, address: CliAddress, root_path: Optional[Path]) -> None:
|
|
387
|
+
new_pool_configs: list[PoolWalletConfig] = []
|
|
388
|
+
id_found = False
|
|
389
|
+
puzzle_hash = address.validate_address_type_get_ph(AddressType.XCH)
|
|
390
|
+
if root_path is None:
|
|
391
|
+
root_path = DEFAULT_ROOT_PATH
|
|
392
|
+
|
|
393
|
+
old_configs: list[PoolWalletConfig] = load_pool_config(root_path)
|
|
394
|
+
for pool_config in old_configs:
|
|
395
|
+
if pool_config.launcher_id == launcher_id:
|
|
396
|
+
id_found = True
|
|
397
|
+
pool_config = replace(pool_config, payout_instructions=puzzle_hash.hex())
|
|
398
|
+
new_pool_configs.append(pool_config)
|
|
399
|
+
if id_found:
|
|
400
|
+
print(f"Launcher Id: {launcher_id.hex()} Found, Updating Config.")
|
|
401
|
+
await update_pool_config(root_path, new_pool_configs)
|
|
402
|
+
print(f"Payout Instructions for launcher id: {launcher_id.hex()} successfully updated to: {address}.")
|
|
403
|
+
print(f"You will need to change the payout instructions on every device you use to: {address}.")
|
|
404
|
+
else:
|
|
405
|
+
print(f"Launcher Id: {launcher_id.hex()} Not found.")
|