chia-blockchain 2.5.2rc2__py3-none-any.whl → 2.5.3rc1__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 +7 -0
- chia/_tests/blockchain/blockchain_test_utils.py +1 -1
- chia/_tests/blockchain/test_augmented_chain.py +54 -5
- chia/_tests/blockchain/test_blockchain.py +5 -12
- chia/_tests/blockchain/test_blockchain_transactions.py +3 -5
- chia/_tests/blockchain/test_get_block_generator.py +2 -2
- chia/_tests/blockchain/test_lookup_fork_chain.py +2 -2
- chia/_tests/clvm/benchmark_costs.py +2 -1
- chia/_tests/clvm/coin_store.py +4 -3
- chia/_tests/clvm/test_chialisp_deserialization.py +2 -2
- chia/_tests/clvm/test_curry_and_treehash.py +1 -1
- chia/_tests/clvm/test_puzzle_compression.py +2 -2
- chia/_tests/clvm/test_puzzles.py +2 -2
- chia/_tests/clvm/test_singletons.py +2 -2
- chia/_tests/clvm/test_spend_sim.py +1 -1
- chia/_tests/cmds/cmd_test_utils.py +2 -2
- chia/_tests/cmds/test_click_types.py +2 -2
- chia/_tests/cmds/test_cmd_framework.py +6 -6
- chia/_tests/cmds/test_show.py +4 -3
- chia/_tests/cmds/test_tx_config_args.py +1 -1
- chia/_tests/cmds/testing_classes.py +2 -2
- chia/_tests/cmds/wallet/test_consts.py +2 -2
- chia/_tests/cmds/wallet/test_did.py +2 -2
- chia/_tests/cmds/wallet/test_nft.py +2 -2
- chia/_tests/cmds/wallet/test_notifications.py +3 -2
- chia/_tests/cmds/wallet/test_vcs.py +2 -2
- chia/_tests/cmds/wallet/test_wallet.py +4 -8
- chia/_tests/conftest.py +4 -3
- chia/_tests/connection_utils.py +2 -2
- chia/_tests/core/cmds/test_keys.py +1 -2
- chia/_tests/core/cmds/test_wallet.py +2 -2
- chia/_tests/core/consensus/test_block_creation.py +2 -2
- chia/_tests/core/consensus/test_pot_iterations.py +1 -1
- chia/_tests/core/custom_types/test_coin.py +2 -2
- chia/_tests/core/custom_types/test_proof_of_space.py +2 -2
- chia/_tests/core/custom_types/test_spend_bundle.py +2 -2
- chia/_tests/core/data_layer/conftest.py +1 -1
- chia/_tests/core/data_layer/test_data_layer.py +1 -1
- chia/_tests/core/data_layer/test_data_layer_util.py +1 -1
- chia/_tests/core/data_layer/test_data_rpc.py +2 -2
- chia/_tests/core/data_layer/test_data_store.py +1 -1
- chia/_tests/core/data_layer/test_data_store_schema.py +1 -1
- chia/_tests/core/data_layer/util.py +2 -1
- chia/_tests/core/farmer/test_farmer_api.py +1 -1
- chia/_tests/core/full_node/full_sync/test_full_sync.py +1 -7
- chia/_tests/core/full_node/ram_db.py +2 -1
- chia/_tests/core/full_node/stores/test_block_store.py +2 -2
- chia/_tests/core/full_node/stores/test_coin_store.py +2 -2
- chia/_tests/core/full_node/stores/test_full_node_store.py +3 -3
- chia/_tests/core/full_node/stores/test_hint_store.py +2 -2
- chia/_tests/core/full_node/stores/test_sync_store.py +1 -1
- chia/_tests/core/full_node/test_address_manager.py +1 -1
- chia/_tests/core/full_node/test_block_height_map.py +2 -2
- chia/_tests/core/full_node/test_conditions.py +1 -1
- chia/_tests/core/full_node/test_full_node.py +346 -164
- chia/_tests/core/full_node/test_generator_tools.py +3 -2
- chia/_tests/core/full_node/test_hint_management.py +2 -2
- chia/_tests/core/full_node/test_performance.py +2 -15
- chia/_tests/core/full_node/test_subscriptions.py +1 -1
- chia/_tests/core/full_node/test_transactions.py +186 -185
- chia/_tests/core/full_node/test_tx_processing_queue.py +1 -1
- chia/_tests/core/make_block_generator.py +2 -2
- chia/_tests/core/mempool/test_mempool.py +165 -22
- chia/_tests/core/mempool/test_mempool_fee_estimator.py +1 -1
- chia/_tests/core/mempool/test_mempool_fee_protocol.py +1 -1
- chia/_tests/core/mempool/test_mempool_manager.py +476 -66
- chia/_tests/core/mempool/test_mempool_performance.py +2 -2
- chia/_tests/core/mempool/test_singleton_fast_forward.py +19 -25
- chia/_tests/core/node_height.py +2 -1
- chia/_tests/core/server/test_capabilities.py +1 -1
- chia/_tests/core/server/test_dos.py +36 -28
- chia/_tests/core/server/test_loop.py +3 -3
- chia/_tests/core/server/test_rate_limits.py +1 -1
- chia/_tests/core/server/test_server.py +2 -2
- chia/_tests/core/services/test_services.py +1 -1
- chia/_tests/core/ssl/test_ssl.py +1 -1
- chia/_tests/core/test_coins.py +2 -1
- chia/_tests/core/test_cost_calculation.py +2 -2
- chia/_tests/core/test_crawler.py +2 -2
- chia/_tests/core/test_db_conversion.py +2 -2
- chia/_tests/core/test_db_validation.py +26 -13
- chia/_tests/core/test_farmer_harvester_rpc.py +2 -2
- chia/_tests/core/test_full_node_rpc.py +2 -2
- chia/_tests/core/test_merkle_set.py +2 -2
- chia/_tests/core/test_program.py +2 -2
- chia/_tests/core/test_rpc_util.py +1 -1
- chia/_tests/core/test_seeder.py +1 -1
- chia/_tests/core/util/test_block_cache.py +3 -3
- chia/_tests/core/util/test_jsonify.py +3 -2
- chia/_tests/core/util/test_keychain.py +3 -3
- chia/_tests/core/util/test_streamable.py +3 -4
- chia/_tests/environments/wallet.py +3 -2
- chia/_tests/farmer_harvester/test_farmer.py +3 -4
- chia/_tests/farmer_harvester/test_farmer_harvester.py +2 -2
- chia/_tests/farmer_harvester/test_filter_prefix_bits.py +2 -2
- chia/_tests/farmer_harvester/test_third_party_harvesters.py +3 -4
- chia/_tests/fee_estimation/test_fee_estimation_integration.py +1 -1
- chia/_tests/fee_estimation/test_fee_estimation_rpc.py +2 -2
- chia/_tests/fee_estimation/test_fee_estimation_unit_tests.py +1 -1
- chia/_tests/fee_estimation/test_mempoolitem_height_added.py +3 -4
- chia/_tests/generator/test_compression.py +20 -10
- chia/_tests/generator/test_rom.py +7 -9
- chia/_tests/plot_sync/test_delta.py +2 -2
- chia/_tests/plot_sync/test_plot_sync.py +2 -2
- chia/_tests/plot_sync/test_receiver.py +2 -2
- chia/_tests/plot_sync/test_sender.py +2 -2
- chia/_tests/plot_sync/test_sync_simulated.py +2 -2
- chia/_tests/plot_sync/util.py +3 -2
- chia/_tests/plotting/test_plot_manager.py +1 -1
- chia/_tests/pools/test_pool_cli_parsing.py +3 -2
- chia/_tests/pools/test_pool_cmdline.py +2 -2
- chia/_tests/pools/test_pool_puzzles_lifecycle.py +3 -3
- chia/_tests/pools/test_pool_rpc.py +4 -5
- chia/_tests/pools/test_pool_wallet.py +1 -1
- chia/_tests/pools/test_wallet_pool_store.py +2 -2
- chia/_tests/rpc/test_rpc_client.py +1 -1
- chia/_tests/rpc/test_rpc_server.py +1 -1
- chia/_tests/simulation/test_simulation.py +36 -8
- chia/_tests/simulation/test_simulator.py +5 -5
- chia/_tests/simulation/test_start_simulator.py +2 -2
- chia/_tests/timelord/test_new_peak.py +2 -2
- chia/_tests/tools/test_run_block.py +3 -2
- chia/_tests/util/benchmark_cost.py +2 -2
- chia/_tests/util/benchmarks.py +17 -6
- chia/_tests/util/blockchain.py +2 -1
- chia/_tests/util/blockchain_mock.py +9 -5
- chia/_tests/util/build_network_protocol_files.py +2 -1
- chia/_tests/util/constants.py +2 -1
- chia/_tests/util/full_sync.py +6 -3
- chia/_tests/util/gen_ssl_certs.py +2 -2
- chia/_tests/util/generator_tools_testing.py +4 -3
- chia/_tests/util/get_name_puzzle_conditions.py +2 -2
- chia/_tests/util/misc.py +16 -2
- chia/_tests/util/network_protocol_data.py +17 -7
- chia/_tests/util/run_block.py +6 -8
- chia/_tests/util/setup_nodes.py +4 -3
- chia/_tests/util/spend_sim.py +9 -5
- chia/_tests/util/test_condition_tools.py +2 -2
- chia/_tests/util/test_config.py +2 -1
- chia/_tests/util/test_errors.py +2 -1
- chia/_tests/util/test_full_block_utils.py +17 -7
- chia/_tests/util/test_misc.py +1 -1
- chia/_tests/util/test_network_protocol_test.py +24 -24
- chia/_tests/util/test_replace_str_to_bytes.py +2 -2
- chia/_tests/util/test_trusted_peer.py +1 -1
- chia/_tests/util/time_out_assert.py +20 -7
- chia/_tests/wallet/cat_wallet/test_cat_lifecycle.py +1 -1
- chia/_tests/wallet/cat_wallet/test_cat_outer_puzzle.py +2 -2
- chia/_tests/wallet/cat_wallet/test_cat_wallet.py +5 -6
- chia/_tests/wallet/cat_wallet/test_offer_lifecycle.py +17 -15
- chia/_tests/wallet/cat_wallet/test_trades.py +2 -2
- chia/_tests/wallet/clawback/test_clawback_lifecycle.py +2 -2
- chia/_tests/wallet/clawback/test_clawback_metadata.py +2 -2
- chia/_tests/wallet/conftest.py +3 -3
- chia/_tests/wallet/db_wallet/test_db_graftroot.py +3 -5
- chia/_tests/wallet/db_wallet/test_dl_offers.py +2 -2
- chia/_tests/wallet/db_wallet/test_dl_wallet.py +433 -384
- chia/_tests/wallet/did_wallet/test_did.py +3 -3
- chia/_tests/wallet/nft_wallet/test_nft_1_offers.py +2 -2
- chia/_tests/wallet/nft_wallet/test_nft_bulk_mint.py +2 -2
- chia/_tests/wallet/nft_wallet/test_nft_lifecycle.py +3 -4
- chia/_tests/wallet/nft_wallet/test_nft_offers.py +1293 -703
- chia/_tests/wallet/nft_wallet/test_nft_puzzles.py +28 -30
- chia/_tests/wallet/nft_wallet/test_nft_wallet.py +2 -2
- chia/_tests/wallet/nft_wallet/test_ownership_outer_puzzle.py +2 -2
- chia/_tests/wallet/rpc/config.py +1 -1
- chia/_tests/wallet/rpc/test_dl_wallet_rpc.py +2 -2
- chia/_tests/wallet/rpc/test_wallet_rpc.py +20 -77
- chia/_tests/wallet/simple_sync/test_simple_sync_protocol.py +9 -7
- chia/_tests/wallet/sync/test_wallet_sync.py +79 -31
- chia/_tests/wallet/test_clvm_streamable.py +2 -2
- chia/_tests/wallet/test_coin_management.py +7 -7
- chia/_tests/wallet/test_coin_selection.py +20 -2
- chia/_tests/wallet/test_conditions.py +2 -2
- chia/_tests/wallet/test_debug_spend_bundle.py +2 -2
- chia/_tests/wallet/test_new_wallet_protocol.py +2 -2
- chia/_tests/wallet/test_nft_store.py +2 -2
- chia/_tests/wallet/test_notifications.py +2 -2
- chia/_tests/wallet/test_puzzle_store.py +2 -2
- chia/_tests/wallet/test_sign_coin_spends.py +2 -2
- chia/_tests/wallet/test_signer_protocol.py +3 -3
- chia/_tests/wallet/test_singleton.py +3 -11
- chia/_tests/wallet/test_singleton_lifecycle_fast.py +12 -13
- chia/_tests/wallet/test_singleton_store.py +2 -4
- chia/_tests/wallet/test_transaction_store.py +2 -2
- chia/_tests/wallet/test_util.py +2 -2
- chia/_tests/wallet/test_wallet.py +53 -49
- chia/_tests/wallet/test_wallet_action_scope.py +24 -6
- chia/_tests/wallet/test_wallet_blockchain.py +1 -1
- chia/_tests/wallet/test_wallet_coin_store.py +2 -2
- chia/_tests/wallet/test_wallet_interested_store.py +2 -2
- chia/_tests/wallet/test_wallet_node.py +3 -3
- chia/_tests/wallet/test_wallet_retry.py +3 -3
- chia/_tests/wallet/test_wallet_state_manager.py +8 -8
- chia/_tests/wallet/test_wallet_test_framework.py +1 -1
- chia/_tests/wallet/test_wallet_trade_store.py +2 -2
- chia/_tests/wallet/test_wallet_utils.py +2 -2
- chia/_tests/wallet/vc_wallet/test_cr_outer_puzzle.py +3 -2
- chia/_tests/wallet/vc_wallet/test_vc_lifecycle.py +15 -15
- chia/_tests/wallet/vc_wallet/test_vc_wallet.py +5 -3
- chia/_tests/wallet/wallet_block_tools.py +15 -7
- chia/_tests/weight_proof/test_weight_proof.py +3 -3
- chia/cmds/chia.py +0 -2
- chia/cmds/cmd_classes.py +3 -3
- chia/cmds/cmd_helpers.py +4 -4
- chia/cmds/cmds_util.py +2 -2
- chia/cmds/coin_funcs.py +3 -2
- chia/cmds/coins.py +1 -1
- chia/cmds/data.py +2 -2
- chia/cmds/data_funcs.py +3 -2
- chia/cmds/db_upgrade_func.py +2 -2
- chia/cmds/db_validate_func.py +15 -8
- chia/cmds/farm.py +2 -4
- chia/cmds/keys.py +0 -2
- chia/cmds/keys_funcs.py +1 -1
- chia/cmds/netspace_funcs.py +2 -1
- chia/cmds/param_types.py +2 -2
- chia/cmds/plotnft.py +2 -2
- chia/cmds/plotnft_funcs.py +2 -2
- chia/cmds/rpc.py +1 -1
- chia/cmds/show.py +1 -2
- chia/cmds/show_funcs.py +6 -3
- chia/cmds/signer.py +1 -2
- chia/cmds/sim.py +1 -2
- chia/cmds/sim_funcs.py +2 -2
- chia/cmds/wallet.py +2 -2
- chia/cmds/wallet_funcs.py +4 -11
- chia/consensus/block_body_validation.py +3 -4
- chia/consensus/block_creation.py +10 -6
- chia/consensus/block_header_validation.py +3 -4
- chia/consensus/block_record.py +2 -3
- chia/consensus/block_rewards.py +1 -1
- chia/consensus/blockchain.py +20 -17
- chia/consensus/blockchain_interface.py +5 -4
- chia/consensus/coinbase.py +2 -2
- chia/consensus/constants.py +1 -1
- chia/consensus/cost_calculator.py +2 -1
- chia/consensus/default_constants.py +4 -3
- chia/consensus/deficit.py +3 -2
- chia/consensus/difficulty_adjustment.py +8 -9
- chia/consensus/find_fork_point.py +4 -3
- chia/consensus/full_block_to_block_record.py +4 -3
- chia/consensus/get_block_challenge.py +4 -3
- chia/consensus/get_block_generator.py +3 -2
- chia/consensus/make_sub_epoch_summary.py +3 -2
- chia/consensus/multiprocess_validation.py +9 -4
- chia/consensus/pos_quality.py +1 -1
- chia/consensus/pot_iterations.py +4 -3
- chia/consensus/vdf_info_computation.py +4 -3
- chia/daemon/client.py +1 -1
- chia/daemon/keychain_server.py +1 -1
- chia/daemon/server.py +1 -1
- chia/daemon/windows_signal.py +1 -1
- chia/data_layer/data_layer.py +4 -3
- chia/data_layer/data_layer_errors.py +1 -1
- chia/data_layer/data_layer_util.py +2 -2
- chia/data_layer/data_layer_wallet.py +47 -69
- chia/data_layer/data_store.py +1 -1
- chia/data_layer/dl_wallet_store.py +5 -6
- chia/data_layer/download_data.py +1 -1
- chia/data_layer/s3_plugin_service.py +4 -4
- chia/data_layer/singleton_record.py +23 -0
- chia/data_layer/util/benchmark.py +2 -1
- chia/farmer/farmer.py +4 -6
- chia/farmer/farmer_api.py +4 -6
- chia/full_node/bitcoin_fee_estimator.py +2 -1
- chia/full_node/block_height_map.py +2 -2
- chia/full_node/block_store.py +8 -9
- chia/{util → full_node}/check_fork_next_block.py +2 -1
- chia/full_node/coin_store.py +10 -10
- chia/full_node/fee_estimate.py +2 -1
- chia/full_node/fee_estimation.py +2 -1
- chia/full_node/fee_estimator.py +2 -1
- chia/full_node/fee_estimator_interface.py +1 -1
- chia/full_node/fee_history.py +2 -1
- chia/full_node/fee_tracker.py +2 -1
- chia/full_node/full_node.py +15 -13
- chia/full_node/full_node_api.py +12 -32
- chia/full_node/full_node_store.py +4 -3
- chia/full_node/hint_management.py +2 -1
- chia/full_node/hint_store.py +3 -3
- chia/full_node/mempool.py +79 -12
- chia/full_node/mempool_check_conditions.py +6 -7
- chia/full_node/mempool_manager.py +168 -21
- chia/full_node/pending_tx_cache.py +2 -2
- chia/full_node/subscriptions.py +2 -2
- chia/full_node/sync_store.py +2 -3
- chia/full_node/tx_processing_queue.py +2 -1
- chia/full_node/weight_proof.py +5 -8
- chia/harvester/harvester.py +5 -3
- chia/harvester/harvester_api.py +2 -2
- chia/introducer/introducer.py +30 -2
- chia/introducer/introducer_api.py +9 -1
- chia/legacy/keyring.py +1 -2
- chia/plot_sync/exceptions.py +2 -1
- chia/plot_sync/receiver.py +2 -2
- chia/plot_sync/sender.py +1 -1
- chia/plotting/cache.py +2 -2
- chia/plotting/check_plots.py +4 -2
- chia/plotting/create_plots.py +1 -1
- chia/plotting/manager.py +3 -3
- chia/plotting/util.py +2 -2
- chia/pools/pool_config.py +1 -1
- chia/pools/pool_puzzles.py +23 -17
- chia/pools/pool_wallet.py +22 -9
- chia/pools/pool_wallet_info.py +2 -2
- chia/protocols/farmer_protocol.py +3 -6
- chia/protocols/full_node_protocol.py +3 -2
- chia/protocols/harvester_protocol.py +3 -4
- chia/protocols/pool_protocol.py +2 -2
- chia/protocols/shared_protocol.py +2 -1
- chia/protocols/timelord_protocol.py +4 -4
- chia/protocols/wallet_protocol.py +2 -2
- chia/rpc/data_layer_rpc_api.py +3 -4
- chia/rpc/data_layer_rpc_client.py +3 -2
- chia/rpc/farmer_rpc_api.py +2 -2
- chia/rpc/farmer_rpc_client.py +2 -1
- chia/rpc/full_node_rpc_api.py +3 -2
- chia/rpc/full_node_rpc_client.py +3 -2
- chia/rpc/harvester_rpc_api.py +2 -1
- chia/rpc/rpc_client.py +2 -2
- chia/rpc/rpc_server.py +1 -1
- chia/rpc/wallet_request_types.py +2 -62
- chia/rpc/wallet_rpc_api.py +98 -628
- chia/rpc/wallet_rpc_client.py +5 -253
- chia/seeder/crawl_store.py +1 -1
- chia/seeder/crawler.py +2 -2
- chia/seeder/peer_record.py +2 -1
- chia/seeder/start_crawler.py +3 -1
- chia/server/address_manager.py +2 -1
- chia/server/address_manager_store.py +1 -1
- chia/server/capabilities.py +2 -1
- chia/server/introducer_peers.py +2 -1
- chia/server/node_discovery.py +1 -1
- chia/server/outbound_message.py +2 -1
- chia/server/server.py +2 -2
- chia/server/start_data_layer.py +2 -1
- chia/server/start_farmer.py +3 -1
- chia/server/start_full_node.py +4 -2
- chia/server/start_harvester.py +3 -1
- chia/server/start_introducer.py +12 -1
- chia/server/start_service.py +2 -1
- chia/server/start_timelord.py +3 -1
- chia/server/start_wallet.py +3 -1
- chia/server/upnp.py +1 -2
- chia/server/ws_connection.py +3 -4
- chia/simulator/add_blocks_in_batches.py +5 -3
- chia/simulator/block_tools.py +16 -12
- chia/simulator/full_node_simulator.py +9 -14
- chia/simulator/setup_services.py +5 -3
- chia/simulator/simulator_full_node_rpc_api.py +3 -2
- chia/simulator/simulator_full_node_rpc_client.py +3 -2
- chia/simulator/simulator_protocol.py +3 -2
- chia/simulator/simulator_test_tools.py +2 -2
- chia/simulator/start_simulator.py +3 -2
- chia/simulator/wallet_tools.py +3 -4
- chia/timelord/iters_from_block.py +4 -4
- chia/timelord/timelord.py +7 -12
- chia/timelord/timelord_api.py +3 -3
- chia/timelord/timelord_state.py +4 -3
- chia/types/block_protocol.py +2 -2
- chia/types/blockchain_format/coin.py +2 -2
- chia/types/blockchain_format/program.py +1 -1
- chia/types/blockchain_format/proof_of_space.py +3 -4
- chia/types/blockchain_format/tree_hash.py +1 -1
- chia/types/blockchain_format/vdf.py +3 -4
- chia/types/clvm_cost.py +1 -1
- chia/types/coin_record.py +4 -3
- chia/types/coin_spend.py +1 -1
- chia/types/eligible_coin_spends.py +9 -5
- chia/types/fee_rate.py +1 -1
- chia/types/generator_types.py +3 -3
- chia/types/internal_mempool_item.py +3 -2
- chia/types/mempool_item.py +10 -3
- chia/types/mempool_submission_status.py +2 -1
- chia/types/mojos.py +1 -1
- chia/types/peer_info.py +2 -1
- chia/types/transaction_queue_entry.py +2 -1
- chia/types/unfinished_header_block.py +4 -4
- chia/types/validation_state.py +2 -1
- chia/types/weight_proof.py +1 -9
- chia/util/augmented_chain.py +20 -9
- chia/util/block_cache.py +8 -4
- chia/util/condition_tools.py +2 -2
- chia/util/full_block_utils.py +3 -4
- chia/util/generator_tools.py +2 -2
- chia/util/initial-config.yaml +2 -11
- chia/util/network.py +2 -2
- chia/util/prev_transaction_block.py +2 -1
- chia/util/task_timing.py +1 -1
- chia/util/vdf_prover.py +3 -3
- chia/util/ws_message.py +1 -1
- chia/wallet/cat_wallet/cat_info.py +3 -2
- chia/wallet/cat_wallet/cat_outer_puzzle.py +3 -2
- chia/wallet/cat_wallet/cat_utils.py +6 -4
- chia/wallet/cat_wallet/cat_wallet.py +16 -18
- chia/wallet/cat_wallet/lineage_store.py +2 -1
- chia/wallet/coin_selection.py +5 -5
- chia/wallet/conditions.py +22 -16
- chia/wallet/db_wallet/db_wallet_puzzles.py +15 -15
- chia/wallet/derivation_record.py +2 -2
- chia/wallet/derive_keys.py +2 -2
- chia/wallet/did_wallet/did_info.py +3 -2
- chia/wallet/did_wallet/did_wallet.py +41 -19
- chia/wallet/did_wallet/did_wallet_puzzles.py +18 -12
- chia/wallet/driver_protocol.py +1 -1
- chia/wallet/lineage_proof.py +3 -2
- chia/wallet/nft_wallet/metadata_outer_puzzle.py +6 -7
- chia/wallet/nft_wallet/nft_info.py +5 -5
- chia/wallet/nft_wallet/nft_puzzle_utils.py +293 -0
- chia/wallet/nft_wallet/nft_puzzles.py +21 -298
- chia/wallet/nft_wallet/nft_wallet.py +47 -62
- chia/wallet/nft_wallet/ownership_outer_puzzle.py +4 -8
- chia/wallet/nft_wallet/singleton_outer_puzzle.py +3 -2
- chia/wallet/nft_wallet/transfer_program_puzzle.py +6 -10
- chia/wallet/nft_wallet/uncurry_nft.py +6 -8
- chia/wallet/notification_manager.py +5 -5
- chia/wallet/notification_store.py +3 -2
- chia/wallet/outer_puzzles.py +2 -1
- chia/wallet/puzzles/clawback/drivers.py +21 -8
- chia/wallet/puzzles/clawback/metadata.py +3 -2
- chia/wallet/puzzles/clawback/puzzle_decorator.py +5 -4
- chia/wallet/puzzles/deployed_puzzle_hashes.json +0 -10
- chia/wallet/puzzles/p2_conditions.py +3 -2
- chia/wallet/puzzles/p2_delegated_conditions.py +3 -2
- chia/wallet/puzzles/p2_delegated_puzzle.py +3 -2
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.py +3 -3
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.py +3 -2
- chia/wallet/puzzles/p2_puzzle_hash.py +4 -3
- chia/wallet/puzzles/puzzle_utils.py +3 -2
- chia/wallet/puzzles/singleton_top_layer.py +26 -10
- chia/wallet/puzzles/singleton_top_layer_v1_1.py +21 -9
- chia/wallet/puzzles/tails.py +21 -129
- chia/wallet/signer_protocol.py +3 -2
- chia/wallet/singleton.py +12 -6
- chia/wallet/singleton_record.py +3 -2
- chia/wallet/trade_manager.py +31 -55
- chia/wallet/trade_record.py +3 -2
- chia/wallet/trading/offer.py +14 -13
- chia/wallet/trading/trade_store.py +3 -4
- chia/wallet/transaction_record.py +2 -2
- chia/wallet/util/blind_signer_tl.py +3 -2
- chia/wallet/util/compute_hints.py +3 -2
- chia/wallet/util/compute_memos.py +2 -2
- chia/wallet/util/curry_and_treehash.py +1 -2
- chia/wallet/util/merkle_tree.py +1 -1
- chia/wallet/util/merkle_utils.py +1 -1
- chia/wallet/util/new_peak_queue.py +2 -1
- chia/wallet/util/notifications.py +5 -4
- chia/wallet/util/peer_request_cache.py +3 -2
- chia/wallet/util/puzzle_compression.py +6 -4
- chia/wallet/util/puzzle_decorator.py +6 -4
- chia/wallet/util/query_filter.py +3 -2
- chia/wallet/util/tx_config.py +3 -3
- chia/wallet/util/wallet_sync_utils.py +2 -2
- chia/wallet/util/wallet_types.py +2 -3
- chia/wallet/vc_wallet/cr_cat_drivers.py +18 -22
- chia/wallet/vc_wallet/cr_cat_wallet.py +14 -10
- chia/wallet/vc_wallet/cr_outer_puzzle.py +2 -2
- chia/wallet/vc_wallet/vc_drivers.py +50 -68
- chia/wallet/vc_wallet/vc_store.py +2 -2
- chia/wallet/vc_wallet/vc_wallet.py +47 -15
- chia/wallet/wallet.py +51 -46
- chia/wallet/wallet_action_scope.py +4 -0
- chia/wallet/wallet_blockchain.py +12 -7
- chia/wallet/wallet_coin_record.py +3 -2
- chia/wallet/wallet_coin_store.py +3 -2
- chia/wallet/wallet_info.py +2 -1
- chia/wallet/wallet_interested_store.py +3 -2
- chia/wallet/wallet_nft_store.py +4 -4
- chia/wallet/wallet_node.py +3 -4
- chia/wallet/wallet_pool_store.py +3 -4
- chia/wallet/wallet_protocol.py +19 -5
- chia/wallet/wallet_puzzle_store.py +2 -2
- chia/wallet/wallet_retry_store.py +3 -6
- chia/wallet/wallet_singleton_store.py +2 -2
- chia/wallet/wallet_state_manager.py +20 -197
- chia/wallet/wallet_transaction_store.py +2 -2
- chia/wallet/wallet_user_store.py +2 -1
- chia/wallet/wallet_weight_proof_handler.py +3 -2
- {chia_blockchain-2.5.2rc2.dist-info → chia_blockchain-2.5.3rc1.dist-info}/METADATA +3 -2
- chia_blockchain-2.5.3rc1.dist-info/RECORD +891 -0
- mozilla-ca/cacert.pem +64 -33
- chia/_tests/clvm/test_condition_codes.py +0 -13
- chia/_tests/cmds/wallet/test_dao.py +0 -565
- chia/_tests/wallet/dao_wallet/__init__.py +0 -0
- chia/_tests/wallet/dao_wallet/config.py +0 -3
- chia/_tests/wallet/dao_wallet/test_dao_clvm.py +0 -1330
- chia/_tests/wallet/dao_wallet/test_dao_wallets.py +0 -3488
- chia/cmds/dao.py +0 -1064
- chia/cmds/dao_funcs.py +0 -598
- chia/consensus/puzzles/__init__.py +0 -0
- chia/consensus/puzzles/chialisp_deserialisation.clsp +0 -69
- chia/consensus/puzzles/chialisp_deserialisation.clsp.hex +0 -1
- chia/consensus/puzzles/rom_bootstrap_generator.clsp +0 -37
- chia/consensus/puzzles/rom_bootstrap_generator.clsp.hex +0 -1
- chia/full_node/puzzles/__init__.py +0 -0
- chia/full_node/puzzles/block_program_zero.clsp +0 -14
- chia/full_node/puzzles/block_program_zero.clsp.hex +0 -1
- chia/full_node/puzzles/decompress_coin_spend_entry.clsp +0 -5
- chia/full_node/puzzles/decompress_coin_spend_entry.clsp.hex +0 -1
- chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp +0 -7
- chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp.hex +0 -1
- chia/full_node/puzzles/decompress_puzzle.clsp +0 -6
- chia/full_node/puzzles/decompress_puzzle.clsp.hex +0 -1
- chia/pools/puzzles/__init__.py +0 -0
- chia/pools/puzzles/pool_member_innerpuz.clsp +0 -70
- chia/pools/puzzles/pool_member_innerpuz.clsp.hex +0 -1
- chia/pools/puzzles/pool_waitingroom_innerpuz.clsp +0 -69
- chia/pools/puzzles/pool_waitingroom_innerpuz.clsp.hex +0 -1
- chia/simulator/simulator_constants.py +0 -13
- chia/types/blockchain_format/foliage.py +0 -8
- chia/types/blockchain_format/pool_target.py +0 -5
- chia/types/blockchain_format/reward_chain_block.py +0 -6
- chia/types/blockchain_format/sized_bytes.py +0 -11
- chia/util/ints.py +0 -19
- chia/wallet/cat_wallet/dao_cat_info.py +0 -28
- chia/wallet/cat_wallet/dao_cat_wallet.py +0 -669
- chia/wallet/cat_wallet/puzzles/__init__.py +0 -0
- chia/wallet/cat_wallet/puzzles/cat_truths.clib +0 -31
- chia/wallet/cat_wallet/puzzles/cat_v2.clsp +0 -397
- chia/wallet/cat_wallet/puzzles/cat_v2.clsp.hex +0 -1
- chia/wallet/cat_wallet/puzzles/delegated_tail.clsp +0 -25
- chia/wallet/cat_wallet/puzzles/delegated_tail.clsp.hex +0 -1
- chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp +0 -15
- chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp.hex +0 -1
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp +0 -26
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp.hex +0 -1
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp +0 -42
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp.hex +0 -1
- chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp +0 -24
- chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp.hex +0 -1
- chia/wallet/dao_wallet/__init__.py +0 -0
- chia/wallet/dao_wallet/dao_info.py +0 -61
- chia/wallet/dao_wallet/dao_utils.py +0 -811
- chia/wallet/dao_wallet/dao_wallet.py +0 -2119
- chia/wallet/did_wallet/puzzles/__init__.py +0 -0
- chia/wallet/did_wallet/puzzles/did_innerpuz.clsp +0 -135
- chia/wallet/did_wallet/puzzles/did_innerpuz.clsp.hex +0 -1
- chia/wallet/payment.py +0 -33
- chia/wallet/puzzles/augmented_condition.clsp +0 -13
- chia/wallet/puzzles/augmented_condition.clsp.hex +0 -1
- chia/wallet/puzzles/condition_codes.clib +0 -77
- chia/wallet/puzzles/curry-and-treehash.clib +0 -102
- chia/wallet/puzzles/curry.clib +0 -135
- chia/wallet/puzzles/curry_by_index.clib +0 -16
- chia/wallet/puzzles/dao_cat_eve.clsp +0 -17
- chia/wallet/puzzles/dao_cat_eve.clsp.hex +0 -1
- chia/wallet/puzzles/dao_cat_launcher.clsp +0 -36
- chia/wallet/puzzles/dao_cat_launcher.clsp.hex +0 -1
- chia/wallet/puzzles/dao_finished_state.clsp +0 -35
- chia/wallet/puzzles/dao_finished_state.clsp.hex +0 -1
- chia/wallet/puzzles/dao_finished_state.clsp.hex.sha256tree +0 -1
- chia/wallet/puzzles/dao_lockup.clsp +0 -288
- chia/wallet/puzzles/dao_lockup.clsp.hex +0 -1
- chia/wallet/puzzles/dao_lockup.clsp.hex.sha256tree +0 -1
- chia/wallet/puzzles/dao_proposal.clsp +0 -377
- chia/wallet/puzzles/dao_proposal.clsp.hex +0 -1
- chia/wallet/puzzles/dao_proposal.clsp.hex.sha256tree +0 -1
- chia/wallet/puzzles/dao_proposal_timer.clsp +0 -78
- chia/wallet/puzzles/dao_proposal_timer.clsp.hex +0 -1
- chia/wallet/puzzles/dao_proposal_timer.clsp.hex.sha256tree +0 -1
- chia/wallet/puzzles/dao_proposal_validator.clsp +0 -87
- chia/wallet/puzzles/dao_proposal_validator.clsp.hex +0 -1
- chia/wallet/puzzles/dao_proposal_validator.clsp.hex.sha256tree +0 -1
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp +0 -240
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex +0 -1
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex.sha256tree +0 -1
- chia/wallet/puzzles/dao_treasury.clsp +0 -115
- chia/wallet/puzzles/dao_treasury.clsp.hex +0 -1
- chia/wallet/puzzles/dao_update_proposal.clsp +0 -44
- chia/wallet/puzzles/dao_update_proposal.clsp.hex +0 -1
- chia/wallet/puzzles/json.clib +0 -25
- chia/wallet/puzzles/merkle_utils.clib +0 -18
- chia/wallet/puzzles/notification.clsp +0 -7
- chia/wallet/puzzles/notification.clsp.hex +0 -1
- chia/wallet/puzzles/p2_1_of_n.clsp +0 -22
- chia/wallet/puzzles/p2_1_of_n.clsp.hex +0 -1
- chia/wallet/puzzles/p2_conditions.clsp +0 -3
- chia/wallet/puzzles/p2_conditions.clsp.hex +0 -1
- chia/wallet/puzzles/p2_delegated_conditions.clsp +0 -18
- chia/wallet/puzzles/p2_delegated_conditions.clsp.hex +0 -1
- chia/wallet/puzzles/p2_delegated_puzzle.clsp +0 -19
- chia/wallet/puzzles/p2_delegated_puzzle.clsp.hex +0 -1
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp +0 -91
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp.hex +0 -1
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp +0 -108
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp.hex +0 -1
- chia/wallet/puzzles/p2_parent.clsp +0 -19
- chia/wallet/puzzles/p2_parent.clsp.hex +0 -1
- chia/wallet/puzzles/p2_puzzle_hash.clsp +0 -18
- chia/wallet/puzzles/p2_puzzle_hash.clsp.hex +0 -1
- chia/wallet/puzzles/p2_singleton.clsp +0 -30
- chia/wallet/puzzles/p2_singleton.clsp.hex +0 -1
- chia/wallet/puzzles/p2_singleton_aggregator.clsp +0 -81
- chia/wallet/puzzles/p2_singleton_aggregator.clsp.hex +0 -1
- chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp +0 -50
- chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp.hex +0 -1
- chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp +0 -47
- chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp.hex +0 -1
- chia/wallet/puzzles/settlement_payments.clsp +0 -49
- chia/wallet/puzzles/settlement_payments.clsp.hex +0 -1
- chia/wallet/puzzles/sha256tree.clib +0 -11
- chia/wallet/puzzles/singleton_launcher.clsp +0 -16
- chia/wallet/puzzles/singleton_launcher.clsp.hex +0 -1
- chia/wallet/puzzles/singleton_top_layer.clsp +0 -177
- chia/wallet/puzzles/singleton_top_layer.clsp.hex +0 -1
- chia/wallet/puzzles/singleton_top_layer_v1_1.clsp +0 -107
- chia/wallet/puzzles/singleton_top_layer_v1_1.clsp.hex +0 -1
- chia/wallet/puzzles/singleton_truths.clib +0 -21
- chia/wallet/vc_wallet/cr_puzzles/__init__.py +0 -0
- chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp +0 -3
- chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp.hex +0 -1
- chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp +0 -304
- chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp.hex +0 -1
- chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp +0 -45
- chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/__init__.py +0 -0
- chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp +0 -30
- chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp +0 -75
- chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp +0 -32
- chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp +0 -80
- chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp +0 -163
- chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp +0 -16
- chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp +0 -74
- chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp +0 -23
- chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp.hex +0 -1
- chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp +0 -64
- chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp.hex +0 -1
- chia_blockchain-2.5.2rc2.dist-info/RECORD +0 -1042
- {chia_blockchain-2.5.2rc2.dist-info → chia_blockchain-2.5.3rc1.dist-info}/LICENSE +0 -0
- {chia_blockchain-2.5.2rc2.dist-info → chia_blockchain-2.5.3rc1.dist-info}/WHEEL +0 -0
- {chia_blockchain-2.5.2rc2.dist-info → chia_blockchain-2.5.3rc1.dist-info}/entry_points.txt +0 -0
chia/cmds/sim_funcs.py
CHANGED
|
@@ -9,18 +9,18 @@ from typing import Any, Optional
|
|
|
9
9
|
|
|
10
10
|
from aiohttp import ClientConnectorError
|
|
11
11
|
from chia_rs import PrivateKey
|
|
12
|
+
from chia_rs.sized_bytes import bytes32
|
|
13
|
+
from chia_rs.sized_ints import uint32
|
|
12
14
|
|
|
13
15
|
from chia.cmds.cmds_util import get_any_service_client
|
|
14
16
|
from chia.cmds.start_funcs import async_start
|
|
15
17
|
from chia.consensus.coinbase import create_puzzlehash_for_pk
|
|
16
18
|
from chia.server.outbound_message import NodeType
|
|
17
19
|
from chia.simulator.simulator_full_node_rpc_client import SimulatorFullNodeRpcClient
|
|
18
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
19
20
|
from chia.types.coin_record import CoinRecord
|
|
20
21
|
from chia.util.bech32m import decode_puzzle_hash, encode_puzzle_hash
|
|
21
22
|
from chia.util.config import load_config, save_config, set_peer_info
|
|
22
23
|
from chia.util.errors import KeychainFingerprintExists
|
|
23
|
-
from chia.util.ints import uint32
|
|
24
24
|
from chia.util.keychain import Keychain, bytes_to_mnemonic
|
|
25
25
|
from chia.wallet.derive_keys import (
|
|
26
26
|
master_sk_to_farmer_sk,
|
chia/cmds/wallet.py
CHANGED
|
@@ -6,6 +6,8 @@ from collections.abc import Sequence
|
|
|
6
6
|
from typing import Optional
|
|
7
7
|
|
|
8
8
|
import click
|
|
9
|
+
from chia_rs.sized_bytes import bytes32
|
|
10
|
+
from chia_rs.sized_ints import uint32, uint64
|
|
9
11
|
|
|
10
12
|
from chia.cmds import options
|
|
11
13
|
from chia.cmds.check_wallet_db import help_text as check_help_text
|
|
@@ -21,8 +23,6 @@ from chia.cmds.param_types import (
|
|
|
21
23
|
cli_amount_none,
|
|
22
24
|
)
|
|
23
25
|
from chia.cmds.signer import PushTransactionsCMD, signer_cmd
|
|
24
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
25
|
-
from chia.util.ints import uint32, uint64
|
|
26
26
|
from chia.wallet.conditions import ConditionValidTimes
|
|
27
27
|
from chia.wallet.transaction_record import TransactionRecord
|
|
28
28
|
from chia.wallet.transaction_sorting import SortKey
|
chia/cmds/wallet_funcs.py
CHANGED
|
@@ -11,6 +11,9 @@ from datetime import datetime, timezone
|
|
|
11
11
|
from decimal import Decimal
|
|
12
12
|
from typing import Any, Callable, Optional, Union
|
|
13
13
|
|
|
14
|
+
from chia_rs.sized_bytes import bytes32
|
|
15
|
+
from chia_rs.sized_ints import uint16, uint32, uint64
|
|
16
|
+
|
|
14
17
|
from chia.cmds.cmds_util import (
|
|
15
18
|
CMDTXConfigLoader,
|
|
16
19
|
cli_confirm,
|
|
@@ -34,11 +37,9 @@ from chia.rpc.wallet_request_types import (
|
|
|
34
37
|
VCSpend,
|
|
35
38
|
)
|
|
36
39
|
from chia.rpc.wallet_rpc_client import WalletRpcClient
|
|
37
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
38
40
|
from chia.util.bech32m import bech32_decode, decode_puzzle_hash, encode_puzzle_hash
|
|
39
41
|
from chia.util.byte_types import hexstr_to_bytes
|
|
40
42
|
from chia.util.config import selected_network_address_prefix
|
|
41
|
-
from chia.util.ints import uint16, uint32, uint64
|
|
42
43
|
from chia.wallet.conditions import ConditionValidTimes, CreateCoinAnnouncement, CreatePuzzleAnnouncement
|
|
43
44
|
from chia.wallet.nft_wallet.nft_info import NFTInfo
|
|
44
45
|
from chia.wallet.outer_puzzles import AssetType
|
|
@@ -111,12 +112,11 @@ def get_mojo_per_unit(wallet_type: WalletType) -> int:
|
|
|
111
112
|
WalletType.POOLING_WALLET,
|
|
112
113
|
WalletType.DATA_LAYER,
|
|
113
114
|
WalletType.VC,
|
|
114
|
-
WalletType.DAO,
|
|
115
115
|
}:
|
|
116
116
|
mojo_per_unit = units["chia"]
|
|
117
117
|
elif wallet_type in {WalletType.CAT, WalletType.CRCAT}:
|
|
118
118
|
mojo_per_unit = units["cat"]
|
|
119
|
-
elif wallet_type in {WalletType.NFT, WalletType.DECENTRALIZED_ID
|
|
119
|
+
elif wallet_type in {WalletType.NFT, WalletType.DECENTRALIZED_ID}:
|
|
120
120
|
mojo_per_unit = units["mojo"]
|
|
121
121
|
else:
|
|
122
122
|
raise LookupError(f"Operation is not supported for Wallet type {wallet_type.name}")
|
|
@@ -940,13 +940,6 @@ async def print_balances(
|
|
|
940
940
|
my_did = get_did_response["did_id"]
|
|
941
941
|
if my_did is not None and len(my_did) > 0:
|
|
942
942
|
print(f"{indent}{'-DID ID:'.ljust(ljust)} {my_did}")
|
|
943
|
-
elif typ == WalletType.DAO:
|
|
944
|
-
get_id_response = await wallet_client.dao_get_treasury_id(wallet_id)
|
|
945
|
-
treasury_id = get_id_response["treasury_id"][2:]
|
|
946
|
-
print(f"{indent}{'-Treasury ID:'.ljust(ljust)} {treasury_id}")
|
|
947
|
-
elif typ == WalletType.DAO_CAT:
|
|
948
|
-
cat_asset_id = summary["data"][32:96]
|
|
949
|
-
print(f"{indent}{'-Asset ID:'.ljust(ljust)} {cat_asset_id}")
|
|
950
943
|
elif len(asset_id) > 0:
|
|
951
944
|
print(f"{indent}{'-Asset ID:'.ljust(ljust)} {asset_id}")
|
|
952
945
|
print(f"{indent}{'-Wallet ID:'.ljust(ljust)} {wallet_id}")
|
|
@@ -6,23 +6,22 @@ from collections.abc import Awaitable, Collection
|
|
|
6
6
|
from dataclasses import dataclass, field
|
|
7
7
|
from typing import Callable, Optional, Union
|
|
8
8
|
|
|
9
|
-
from chia_rs import SpendBundleConditions, compute_merkle_set_root
|
|
9
|
+
from chia_rs import ConsensusConstants, SpendBundleConditions, compute_merkle_set_root
|
|
10
|
+
from chia_rs.sized_bytes import bytes32
|
|
11
|
+
from chia_rs.sized_ints import uint32, uint64
|
|
10
12
|
from chiabip158 import PyBIP158
|
|
11
13
|
|
|
12
14
|
from chia.consensus.block_record import BlockRecord
|
|
13
15
|
from chia.consensus.block_rewards import calculate_base_farmer_reward, calculate_pool_reward
|
|
14
16
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
15
17
|
from chia.consensus.coinbase import create_farmer_coin, create_pool_coin
|
|
16
|
-
from chia.consensus.constants import ConsensusConstants
|
|
17
18
|
from chia.full_node.mempool_check_conditions import mempool_check_time_locks
|
|
18
19
|
from chia.types.blockchain_format.coin import Coin, hash_coin_ids
|
|
19
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
20
20
|
from chia.types.coin_record import CoinRecord
|
|
21
21
|
from chia.types.full_block import FullBlock
|
|
22
22
|
from chia.types.unfinished_block import UnfinishedBlock
|
|
23
23
|
from chia.util.errors import Err
|
|
24
24
|
from chia.util.hash import std_hash
|
|
25
|
-
from chia.util.ints import uint32, uint64
|
|
26
25
|
|
|
27
26
|
log = logging.getLogger(__name__)
|
|
28
27
|
|
chia/consensus/block_creation.py
CHANGED
|
@@ -9,34 +9,38 @@ import chia_rs
|
|
|
9
9
|
from chia_rs import (
|
|
10
10
|
DONT_VALIDATE_SIGNATURE,
|
|
11
11
|
MEMPOOL_MODE,
|
|
12
|
+
ConsensusConstants,
|
|
13
|
+
Foliage,
|
|
14
|
+
FoliageBlockData,
|
|
15
|
+
FoliageTransactionBlock,
|
|
12
16
|
G1Element,
|
|
13
17
|
G2Element,
|
|
18
|
+
PoolTarget,
|
|
19
|
+
RewardChainBlock,
|
|
20
|
+
RewardChainBlockUnfinished,
|
|
21
|
+
TransactionsInfo,
|
|
14
22
|
compute_merkle_set_root,
|
|
15
23
|
get_flags_for_height_and_constants,
|
|
16
24
|
run_block_generator,
|
|
17
25
|
run_block_generator2,
|
|
18
26
|
)
|
|
27
|
+
from chia_rs.sized_bytes import bytes32
|
|
28
|
+
from chia_rs.sized_ints import uint8, uint32, uint64, uint128
|
|
19
29
|
from chiabip158 import PyBIP158
|
|
20
30
|
|
|
21
31
|
from chia.consensus.block_record import BlockRecord
|
|
22
32
|
from chia.consensus.block_rewards import calculate_base_farmer_reward, calculate_pool_reward
|
|
23
33
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
24
34
|
from chia.consensus.coinbase import create_farmer_coin, create_pool_coin
|
|
25
|
-
from chia.consensus.constants import ConsensusConstants
|
|
26
35
|
from chia.full_node.signage_point import SignagePoint
|
|
27
36
|
from chia.types.blockchain_format.coin import Coin, hash_coin_ids
|
|
28
|
-
from chia.types.blockchain_format.foliage import Foliage, FoliageBlockData, FoliageTransactionBlock, TransactionsInfo
|
|
29
|
-
from chia.types.blockchain_format.pool_target import PoolTarget
|
|
30
37
|
from chia.types.blockchain_format.proof_of_space import ProofOfSpace
|
|
31
|
-
from chia.types.blockchain_format.reward_chain_block import RewardChainBlock, RewardChainBlockUnfinished
|
|
32
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
33
38
|
from chia.types.blockchain_format.vdf import VDFInfo, VDFProof
|
|
34
39
|
from chia.types.end_of_slot_bundle import EndOfSubSlotBundle
|
|
35
40
|
from chia.types.full_block import FullBlock
|
|
36
41
|
from chia.types.generator_types import BlockGenerator
|
|
37
42
|
from chia.types.unfinished_block import UnfinishedBlock
|
|
38
43
|
from chia.util.hash import std_hash
|
|
39
|
-
from chia.util.ints import uint8, uint32, uint64, uint128
|
|
40
44
|
from chia.util.prev_transaction_block import get_prev_transaction_block
|
|
41
45
|
|
|
42
46
|
log = logging.getLogger(__name__)
|
|
@@ -4,11 +4,12 @@ import logging
|
|
|
4
4
|
import time
|
|
5
5
|
from typing import Optional
|
|
6
6
|
|
|
7
|
-
from chia_rs import AugSchemeMPL
|
|
7
|
+
from chia_rs import AugSchemeMPL, ConsensusConstants
|
|
8
|
+
from chia_rs.sized_bytes import bytes32
|
|
9
|
+
from chia_rs.sized_ints import uint8, uint32, uint64, uint128
|
|
8
10
|
|
|
9
11
|
from chia.consensus.block_record import BlockRecord
|
|
10
12
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
11
|
-
from chia.consensus.constants import ConsensusConstants
|
|
12
13
|
from chia.consensus.deficit import calculate_deficit
|
|
13
14
|
from chia.consensus.difficulty_adjustment import can_finish_sub_and_full_epoch
|
|
14
15
|
from chia.consensus.get_block_challenge import final_eos_is_already_included, get_block_challenge
|
|
@@ -23,7 +24,6 @@ from chia.consensus.pot_iterations import (
|
|
|
23
24
|
from chia.consensus.vdf_info_computation import get_signage_point_vdf_info
|
|
24
25
|
from chia.types.blockchain_format.classgroup import ClassgroupElement
|
|
25
26
|
from chia.types.blockchain_format.proof_of_space import verify_and_get_quality_string
|
|
26
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
27
27
|
from chia.types.blockchain_format.slots import ChallengeChainSubSlot, RewardChainSubSlot, SubSlotProofs
|
|
28
28
|
from chia.types.blockchain_format.vdf import VDFInfo, VDFProof, validate_vdf
|
|
29
29
|
from chia.types.end_of_slot_bundle import EndOfSubSlotBundle
|
|
@@ -32,7 +32,6 @@ from chia.types.unfinished_header_block import UnfinishedHeaderBlock
|
|
|
32
32
|
from chia.types.validation_state import ValidationState
|
|
33
33
|
from chia.util.errors import Err, ValidationError
|
|
34
34
|
from chia.util.hash import std_hash
|
|
35
|
-
from chia.util.ints import uint8, uint32, uint64, uint128
|
|
36
35
|
|
|
37
36
|
log = logging.getLogger(__name__)
|
|
38
37
|
|
chia/consensus/block_record.py
CHANGED
|
@@ -3,11 +3,10 @@ from __future__ import annotations
|
|
|
3
3
|
from typing import Optional
|
|
4
4
|
|
|
5
5
|
import chia_rs
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint32, uint64
|
|
6
8
|
from typing_extensions import Protocol
|
|
7
9
|
|
|
8
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
9
|
-
from chia.util.ints import uint32, uint64
|
|
10
|
-
|
|
11
10
|
BlockRecord = chia_rs.BlockRecord
|
|
12
11
|
|
|
13
12
|
|
chia/consensus/block_rewards.py
CHANGED
chia/consensus/blockchain.py
CHANGED
|
@@ -10,12 +10,18 @@ from enum import Enum
|
|
|
10
10
|
from pathlib import Path
|
|
11
11
|
from typing import TYPE_CHECKING, ClassVar, Optional, cast
|
|
12
12
|
|
|
13
|
-
from chia_rs import
|
|
13
|
+
from chia_rs import (
|
|
14
|
+
ConsensusConstants,
|
|
15
|
+
SubEpochChallengeSegment,
|
|
16
|
+
additions_and_removals,
|
|
17
|
+
get_flags_for_height_and_constants,
|
|
18
|
+
)
|
|
19
|
+
from chia_rs.sized_bytes import bytes32
|
|
20
|
+
from chia_rs.sized_ints import uint16, uint32, uint64, uint128
|
|
14
21
|
|
|
15
22
|
from chia.consensus.block_body_validation import ForkInfo, validate_block_body
|
|
16
23
|
from chia.consensus.block_header_validation import validate_unfinished_header_block
|
|
17
24
|
from chia.consensus.block_record import BlockRecord
|
|
18
|
-
from chia.consensus.constants import ConsensusConstants
|
|
19
25
|
from chia.consensus.cost_calculator import NPCResult
|
|
20
26
|
from chia.consensus.difficulty_adjustment import get_next_sub_slot_iters_and_difficulty
|
|
21
27
|
from chia.consensus.find_fork_point import lookup_fork_chain
|
|
@@ -26,7 +32,6 @@ from chia.full_node.block_height_map import BlockHeightMap
|
|
|
26
32
|
from chia.full_node.block_store import BlockStore
|
|
27
33
|
from chia.full_node.coin_store import CoinStore
|
|
28
34
|
from chia.types.blockchain_format.coin import Coin
|
|
29
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
30
35
|
from chia.types.blockchain_format.sub_epoch_summary import SubEpochSummary
|
|
31
36
|
from chia.types.blockchain_format.vdf import VDFInfo
|
|
32
37
|
from chia.types.coin_record import CoinRecord
|
|
@@ -37,13 +42,11 @@ from chia.types.header_block import HeaderBlock
|
|
|
37
42
|
from chia.types.unfinished_block import UnfinishedBlock
|
|
38
43
|
from chia.types.unfinished_header_block import UnfinishedHeaderBlock
|
|
39
44
|
from chia.types.validation_state import ValidationState
|
|
40
|
-
from chia.types.weight_proof import SubEpochChallengeSegment
|
|
41
45
|
from chia.util.cpu import available_logical_cores
|
|
42
46
|
from chia.util.errors import Err
|
|
43
47
|
from chia.util.generator_tools import get_block_header
|
|
44
48
|
from chia.util.hash import std_hash
|
|
45
49
|
from chia.util.inline_executor import InlineExecutor
|
|
46
|
-
from chia.util.ints import uint16, uint32, uint64, uint128
|
|
47
50
|
from chia.util.priority_mutex import PriorityMutex
|
|
48
51
|
|
|
49
52
|
log = logging.getLogger(__name__)
|
|
@@ -146,6 +149,7 @@ class Blockchain:
|
|
|
146
149
|
num_workers = max(cpu_count - reserved_cores, 1)
|
|
147
150
|
self.pool = ThreadPoolExecutor(
|
|
148
151
|
max_workers=num_workers,
|
|
152
|
+
thread_name_prefix="block-validation-",
|
|
149
153
|
)
|
|
150
154
|
log.info(f"Started {num_workers} processes for block validation")
|
|
151
155
|
|
|
@@ -609,16 +613,16 @@ class Blockchain:
|
|
|
609
613
|
)
|
|
610
614
|
|
|
611
615
|
def get_next_difficulty(self, header_hash: bytes32, new_slot: bool) -> uint64:
|
|
612
|
-
|
|
613
|
-
curr
|
|
616
|
+
curr = self.try_block_record(header_hash)
|
|
617
|
+
assert curr is not None
|
|
614
618
|
if curr.height <= 2:
|
|
615
619
|
return self.constants.DIFFICULTY_STARTING
|
|
616
620
|
|
|
617
621
|
return get_next_sub_slot_iters_and_difficulty(self.constants, new_slot, curr, self)[1]
|
|
618
622
|
|
|
619
623
|
def get_next_slot_iters(self, header_hash: bytes32, new_slot: bool) -> uint64:
|
|
620
|
-
|
|
621
|
-
curr
|
|
624
|
+
curr = self.try_block_record(header_hash)
|
|
625
|
+
assert curr is not None
|
|
622
626
|
if curr.height <= 2:
|
|
623
627
|
return self.constants.SUB_SLOT_ITERS_STARTING
|
|
624
628
|
return get_next_sub_slot_iters_and_difficulty(self.constants, new_slot, curr, self)[0]
|
|
@@ -704,7 +708,7 @@ class Blockchain:
|
|
|
704
708
|
return None, Err.TOO_MANY_GENERATOR_REFS
|
|
705
709
|
|
|
706
710
|
if (
|
|
707
|
-
|
|
711
|
+
self.try_block_record(block.prev_header_hash) is None
|
|
708
712
|
and block.prev_header_hash != self.constants.GENESIS_CHALLENGE
|
|
709
713
|
):
|
|
710
714
|
return None, Err.INVALID_PREV_BLOCK_HASH
|
|
@@ -788,12 +792,11 @@ class Blockchain:
|
|
|
788
792
|
|
|
789
793
|
return PreValidationResult(None, required_iters, conds, uint32(0))
|
|
790
794
|
|
|
791
|
-
def contains_block(self, header_hash: bytes32) -> bool:
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
return header_hash in self.__block_records
|
|
795
|
+
def contains_block(self, header_hash: bytes32, height: uint32) -> bool:
|
|
796
|
+
block_hash_from_hh = self.height_to_hash(height)
|
|
797
|
+
if block_hash_from_hh is None or block_hash_from_hh != header_hash:
|
|
798
|
+
return False
|
|
799
|
+
return True
|
|
797
800
|
|
|
798
801
|
def block_record(self, header_hash: bytes32) -> BlockRecord:
|
|
799
802
|
return self.__block_records[header_hash]
|
|
@@ -955,7 +958,7 @@ class Blockchain:
|
|
|
955
958
|
return records
|
|
956
959
|
|
|
957
960
|
def try_block_record(self, header_hash: bytes32) -> Optional[BlockRecord]:
|
|
958
|
-
if self.
|
|
961
|
+
if header_hash in self.__block_records:
|
|
959
962
|
return self.block_record(header_hash)
|
|
960
963
|
return None
|
|
961
964
|
|
|
@@ -2,19 +2,20 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Optional, Protocol
|
|
4
4
|
|
|
5
|
+
from chia_rs import SubEpochChallengeSegment
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint32
|
|
8
|
+
|
|
5
9
|
from chia.consensus.block_record import BlockRecord
|
|
6
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
7
10
|
from chia.types.blockchain_format.sub_epoch_summary import SubEpochSummary
|
|
8
11
|
from chia.types.header_block import HeaderBlock
|
|
9
|
-
from chia.types.weight_proof import SubEpochChallengeSegment
|
|
10
|
-
from chia.util.ints import uint32
|
|
11
12
|
|
|
12
13
|
|
|
13
14
|
class BlockRecordsProtocol(Protocol):
|
|
14
15
|
def try_block_record(self, header_hash: bytes32) -> Optional[BlockRecord]: ...
|
|
15
16
|
def block_record(self, header_hash: bytes32) -> BlockRecord: ...
|
|
16
17
|
def contains_height(self, height: uint32) -> bool: ...
|
|
17
|
-
def contains_block(self, header_hash: bytes32) -> bool: ...
|
|
18
|
+
def contains_block(self, header_hash: bytes32, height: uint32) -> bool: ...
|
|
18
19
|
def height_to_hash(self, height: uint32) -> Optional[bytes32]: ...
|
|
19
20
|
def height_to_block_record(self, height: uint32) -> BlockRecord: ...
|
|
20
21
|
|
chia/consensus/coinbase.py
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
3
|
from chia_rs import G1Element
|
|
4
|
+
from chia_rs.sized_bytes import bytes32
|
|
5
|
+
from chia_rs.sized_ints import uint32, uint64
|
|
4
6
|
|
|
5
7
|
from chia.types.blockchain_format.coin import Coin
|
|
6
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
7
|
-
from chia.util.ints import uint32, uint64
|
|
8
8
|
from chia.wallet.puzzles.p2_delegated_puzzle_or_hidden_puzzle import puzzle_hash_for_pk
|
|
9
9
|
|
|
10
10
|
|
chia/consensus/constants.py
CHANGED
|
@@ -3,7 +3,7 @@ from __future__ import annotations
|
|
|
3
3
|
import logging
|
|
4
4
|
from typing import Any
|
|
5
5
|
|
|
6
|
-
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs import ConsensusConstants
|
|
7
7
|
|
|
8
8
|
from chia.util.byte_types import hexstr_to_bytes
|
|
9
9
|
from chia.util.hash import std_hash
|
|
@@ -3,8 +3,9 @@ from __future__ import annotations
|
|
|
3
3
|
from dataclasses import dataclass
|
|
4
4
|
from typing import Optional
|
|
5
5
|
|
|
6
|
+
from chia_rs.sized_ints import uint16
|
|
7
|
+
|
|
6
8
|
from chia.types.spend_bundle_conditions import SpendBundleConditions
|
|
7
|
-
from chia.util.ints import uint16
|
|
8
9
|
from chia.util.streamable import Streamable, streamable
|
|
9
10
|
|
|
10
11
|
|
|
@@ -2,10 +2,11 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Any
|
|
4
4
|
|
|
5
|
-
from
|
|
6
|
-
from
|
|
5
|
+
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint8, uint16, uint32, uint64, uint128
|
|
8
|
+
|
|
7
9
|
from chia.util.hash import std_hash
|
|
8
|
-
from chia.util.ints import uint8, uint16, uint32, uint64, uint128
|
|
9
10
|
|
|
10
11
|
AGG_SIG_DATA = bytes32.fromhex("ccd5bb71183532bff220ba46c268991a3ff07eb358e8255a65c30a2dce0e5fbb")
|
|
11
12
|
|
chia/consensus/deficit.py
CHANGED
|
@@ -2,9 +2,10 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Optional
|
|
4
4
|
|
|
5
|
+
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs.sized_ints import uint8, uint32
|
|
7
|
+
|
|
5
8
|
from chia.consensus.block_record import BlockRecord
|
|
6
|
-
from chia.consensus.constants import ConsensusConstants
|
|
7
|
-
from chia.util.ints import uint8, uint32
|
|
8
9
|
|
|
9
10
|
|
|
10
11
|
def calculate_deficit(
|
|
@@ -2,11 +2,12 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Optional
|
|
4
4
|
|
|
5
|
+
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint8, uint32, uint64, uint128
|
|
8
|
+
|
|
5
9
|
from chia.consensus.block_record import BlockRecord
|
|
6
10
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
7
|
-
from chia.consensus.constants import ConsensusConstants
|
|
8
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
9
|
-
from chia.util.ints import uint8, uint32, uint64, uint128
|
|
10
11
|
from chia.util.significant_bits import count_significant_bits, truncate_to_significant_bits
|
|
11
12
|
|
|
12
13
|
|
|
@@ -224,11 +225,10 @@ def _get_next_sub_slot_iters(
|
|
|
224
225
|
if next_height < constants.EPOCH_BLOCKS:
|
|
225
226
|
return uint64(constants.SUB_SLOT_ITERS_STARTING)
|
|
226
227
|
|
|
227
|
-
|
|
228
|
+
prev_b = blocks.try_block_record(prev_header_hash)
|
|
229
|
+
if prev_b is None:
|
|
228
230
|
raise ValueError(f"Header hash {prev_header_hash} not in blocks")
|
|
229
231
|
|
|
230
|
-
prev_b: BlockRecord = blocks.block_record(prev_header_hash)
|
|
231
|
-
|
|
232
232
|
# If we are in the same epoch, return same ssi
|
|
233
233
|
if not skip_epoch_check:
|
|
234
234
|
_, can_finish_epoch = can_finish_sub_and_full_epoch(
|
|
@@ -304,11 +304,10 @@ def _get_next_difficulty(
|
|
|
304
304
|
# We are in the first epoch
|
|
305
305
|
return uint64(constants.DIFFICULTY_STARTING)
|
|
306
306
|
|
|
307
|
-
|
|
307
|
+
prev_b = blocks.try_block_record(prev_header_hash)
|
|
308
|
+
if prev_b is None:
|
|
308
309
|
raise ValueError(f"Header hash {prev_header_hash} not in blocks")
|
|
309
310
|
|
|
310
|
-
prev_b: BlockRecord = blocks.block_record(prev_header_hash)
|
|
311
|
-
|
|
312
311
|
# If we are in the same slot as previous block, return same difficulty
|
|
313
312
|
if not skip_epoch_check:
|
|
314
313
|
_, can_finish_epoch = can_finish_sub_and_full_epoch(
|
|
@@ -2,12 +2,13 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Union
|
|
4
4
|
|
|
5
|
+
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint32
|
|
8
|
+
|
|
5
9
|
from chia.consensus.block_record import BlockRecord
|
|
6
10
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
7
|
-
from chia.consensus.constants import ConsensusConstants
|
|
8
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
9
11
|
from chia.types.header_block import HeaderBlock
|
|
10
|
-
from chia.util.ints import uint32
|
|
11
12
|
|
|
12
13
|
|
|
13
14
|
async def find_fork_point_in_chain(
|
|
@@ -2,21 +2,22 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Optional, Union
|
|
4
4
|
|
|
5
|
+
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint8, uint32, uint64
|
|
8
|
+
|
|
5
9
|
from chia.consensus.block_record import BlockRecord
|
|
6
10
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
7
|
-
from chia.consensus.constants import ConsensusConstants
|
|
8
11
|
from chia.consensus.deficit import calculate_deficit
|
|
9
12
|
from chia.consensus.difficulty_adjustment import get_next_sub_slot_iters_and_difficulty
|
|
10
13
|
from chia.consensus.make_sub_epoch_summary import make_sub_epoch_summary
|
|
11
14
|
from chia.consensus.pot_iterations import is_overflow_block
|
|
12
15
|
from chia.types.blockchain_format.classgroup import ClassgroupElement
|
|
13
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
14
16
|
from chia.types.blockchain_format.slots import ChallengeBlockInfo
|
|
15
17
|
from chia.types.blockchain_format.sub_epoch_summary import SubEpochSummary
|
|
16
18
|
from chia.types.full_block import FullBlock
|
|
17
19
|
from chia.types.header_block import HeaderBlock
|
|
18
20
|
from chia.util.errors import Err
|
|
19
|
-
from chia.util.ints import uint8, uint32, uint64
|
|
20
21
|
|
|
21
22
|
|
|
22
23
|
def block_to_block_record(
|
|
@@ -3,15 +3,16 @@ from __future__ import annotations
|
|
|
3
3
|
import logging
|
|
4
4
|
from typing import Union
|
|
5
5
|
|
|
6
|
+
from chia_rs import ConsensusConstants
|
|
7
|
+
from chia_rs.sized_bytes import bytes32
|
|
8
|
+
from chia_rs.sized_ints import uint64
|
|
9
|
+
|
|
6
10
|
from chia.consensus.block_record import BlockRecord
|
|
7
11
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
8
|
-
from chia.consensus.constants import ConsensusConstants
|
|
9
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
10
12
|
from chia.types.full_block import FullBlock
|
|
11
13
|
from chia.types.header_block import HeaderBlock
|
|
12
14
|
from chia.types.unfinished_block import UnfinishedBlock
|
|
13
15
|
from chia.types.unfinished_header_block import UnfinishedHeaderBlock
|
|
14
|
-
from chia.util.ints import uint64
|
|
15
16
|
|
|
16
17
|
log = logging.getLogger(__name__)
|
|
17
18
|
|
|
@@ -3,10 +3,11 @@ from __future__ import annotations
|
|
|
3
3
|
from collections.abc import Awaitable
|
|
4
4
|
from typing import Callable, Optional
|
|
5
5
|
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint32
|
|
8
|
+
|
|
6
9
|
from chia.types.block_protocol import BlockInfo
|
|
7
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
8
10
|
from chia.types.generator_types import BlockGenerator
|
|
9
|
-
from chia.util.ints import uint32
|
|
10
11
|
|
|
11
12
|
|
|
12
13
|
async def get_block_generator(
|
|
@@ -3,9 +3,11 @@ from __future__ import annotations
|
|
|
3
3
|
import logging
|
|
4
4
|
from typing import Optional, Union
|
|
5
5
|
|
|
6
|
+
from chia_rs import ConsensusConstants
|
|
7
|
+
from chia_rs.sized_ints import uint8, uint32, uint64, uint128
|
|
8
|
+
|
|
6
9
|
from chia.consensus.block_record import BlockRecord
|
|
7
10
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
8
|
-
from chia.consensus.constants import ConsensusConstants
|
|
9
11
|
from chia.consensus.deficit import calculate_deficit
|
|
10
12
|
from chia.consensus.difficulty_adjustment import (
|
|
11
13
|
_get_next_difficulty,
|
|
@@ -18,7 +20,6 @@ from chia.consensus.pot_iterations import calculate_ip_iters, calculate_sp_iters
|
|
|
18
20
|
from chia.types.blockchain_format.sub_epoch_summary import SubEpochSummary
|
|
19
21
|
from chia.types.full_block import FullBlock
|
|
20
22
|
from chia.types.unfinished_block import UnfinishedBlock
|
|
21
|
-
from chia.util.ints import uint8, uint32, uint64, uint128
|
|
22
23
|
|
|
23
24
|
log = logging.getLogger(__name__)
|
|
24
25
|
|
|
@@ -10,19 +10,25 @@ from concurrent.futures import Executor
|
|
|
10
10
|
from dataclasses import dataclass
|
|
11
11
|
from typing import Optional
|
|
12
12
|
|
|
13
|
-
from chia_rs import
|
|
13
|
+
from chia_rs import (
|
|
14
|
+
ConsensusConstants,
|
|
15
|
+
SpendBundleConditions,
|
|
16
|
+
get_flags_for_height_and_constants,
|
|
17
|
+
run_block_generator,
|
|
18
|
+
run_block_generator2,
|
|
19
|
+
)
|
|
20
|
+
from chia_rs.sized_bytes import bytes32
|
|
21
|
+
from chia_rs.sized_ints import uint16, uint32, uint64
|
|
14
22
|
|
|
15
23
|
from chia.consensus.block_header_validation import validate_finished_header_block
|
|
16
24
|
from chia.consensus.block_record import BlockRecord
|
|
17
25
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
18
|
-
from chia.consensus.constants import ConsensusConstants
|
|
19
26
|
from chia.consensus.full_block_to_block_record import block_to_block_record
|
|
20
27
|
from chia.consensus.get_block_challenge import get_block_challenge
|
|
21
28
|
from chia.consensus.get_block_generator import get_block_generator
|
|
22
29
|
from chia.consensus.pot_iterations import calculate_iterations_quality, is_overflow_block
|
|
23
30
|
from chia.types.blockchain_format.coin import Coin
|
|
24
31
|
from chia.types.blockchain_format.proof_of_space import verify_and_get_quality_string
|
|
25
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
26
32
|
from chia.types.blockchain_format.sub_epoch_summary import SubEpochSummary
|
|
27
33
|
from chia.types.full_block import FullBlock
|
|
28
34
|
from chia.types.generator_types import BlockGenerator
|
|
@@ -30,7 +36,6 @@ from chia.types.validation_state import ValidationState
|
|
|
30
36
|
from chia.util.augmented_chain import AugmentedBlockchain
|
|
31
37
|
from chia.util.errors import Err
|
|
32
38
|
from chia.util.generator_tools import get_block_header, tx_removals_and_additions
|
|
33
|
-
from chia.util.ints import uint16, uint32, uint64
|
|
34
39
|
from chia.util.streamable import Streamable, streamable
|
|
35
40
|
|
|
36
41
|
log = logging.getLogger(__name__)
|
chia/consensus/pos_quality.py
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from
|
|
3
|
+
from chia_rs.sized_ints import uint64
|
|
4
4
|
|
|
5
5
|
# The actual space in bytes of a plot, is _expected_plot_size(k) * UI_ACTUAL_SPACE_CONSTANT_FACTO
|
|
6
6
|
# This is not used in consensus, only for display purposes
|
chia/consensus/pot_iterations.py
CHANGED
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from
|
|
3
|
+
from chia_rs import ConsensusConstants
|
|
4
|
+
from chia_rs.sized_bytes import bytes32
|
|
5
|
+
from chia_rs.sized_ints import uint8, uint64, uint128
|
|
6
|
+
|
|
4
7
|
from chia.consensus.pos_quality import _expected_plot_size
|
|
5
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
6
8
|
from chia.util.hash import std_hash
|
|
7
|
-
from chia.util.ints import uint8, uint64, uint128
|
|
8
9
|
|
|
9
10
|
|
|
10
11
|
def is_overflow_block(constants: ConsensusConstants, signage_point_index: uint8) -> bool:
|
|
@@ -2,13 +2,14 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
from typing import Optional
|
|
4
4
|
|
|
5
|
+
from chia_rs import ConsensusConstants
|
|
6
|
+
from chia_rs.sized_bytes import bytes32
|
|
7
|
+
from chia_rs.sized_ints import uint64, uint128
|
|
8
|
+
|
|
5
9
|
from chia.consensus.block_record import BlockRecord
|
|
6
10
|
from chia.consensus.blockchain_interface import BlockRecordsProtocol
|
|
7
|
-
from chia.consensus.constants import ConsensusConstants
|
|
8
11
|
from chia.types.blockchain_format.classgroup import ClassgroupElement
|
|
9
|
-
from chia.types.blockchain_format.sized_bytes import bytes32
|
|
10
12
|
from chia.types.end_of_slot_bundle import EndOfSubSlotBundle
|
|
11
|
-
from chia.util.ints import uint64, uint128
|
|
12
13
|
|
|
13
14
|
|
|
14
15
|
def get_signage_point_vdf_info(
|
chia/daemon/client.py
CHANGED
|
@@ -9,8 +9,8 @@ from pathlib import Path
|
|
|
9
9
|
from typing import Any, Optional
|
|
10
10
|
|
|
11
11
|
import aiohttp
|
|
12
|
+
from chia_rs.sized_ints import uint32
|
|
12
13
|
|
|
13
|
-
from chia.util.ints import uint32
|
|
14
14
|
from chia.util.json_util import dict_to_json_str
|
|
15
15
|
from chia.util.task_referencer import create_referenced_task
|
|
16
16
|
from chia.util.ws_message import WsRpcMessage, create_payload_dict
|