chia-blockchain 2.5.0rc2__py3-none-any.whl → 2.5.1rc2__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/_tests/README.md +1 -1
- chia/_tests/blockchain/blockchain_test_utils.py +24 -26
- chia/_tests/blockchain/test_augmented_chain.py +6 -8
- chia/_tests/blockchain/test_blockchain.py +409 -307
- chia/_tests/blockchain/test_blockchain_transactions.py +56 -75
- chia/_tests/blockchain/test_build_chains.py +11 -13
- chia/_tests/blockchain/test_get_block_generator.py +8 -8
- chia/_tests/blockchain/test_lookup_fork_chain.py +3 -4
- chia/_tests/build-init-files.py +3 -4
- chia/_tests/build-job-matrix.py +9 -9
- chia/_tests/check_sql_statements.py +2 -3
- chia/_tests/clvm/benchmark_costs.py +1 -1
- chia/_tests/clvm/coin_store.py +7 -5
- chia/_tests/clvm/test_chialisp_deserialization.py +8 -8
- chia/_tests/clvm/test_condition_codes.py +2 -2
- chia/_tests/clvm/test_curry_and_treehash.py +2 -4
- chia/_tests/clvm/test_message_conditions.py +184 -0
- chia/_tests/clvm/test_puzzle_compression.py +1 -2
- chia/_tests/clvm/test_puzzle_drivers.py +3 -3
- chia/_tests/clvm/test_puzzles.py +13 -18
- chia/_tests/clvm/test_singletons.py +17 -17
- chia/_tests/clvm/test_spend_sim.py +7 -7
- chia/_tests/cmds/cmd_test_utils.py +42 -45
- chia/_tests/cmds/conftest.py +2 -2
- chia/_tests/cmds/test_click_types.py +21 -16
- chia/_tests/cmds/test_cmd_framework.py +255 -35
- chia/_tests/cmds/test_cmds_util.py +2 -2
- chia/_tests/cmds/test_daemon.py +3 -3
- chia/_tests/cmds/test_dev_gh.py +131 -0
- chia/_tests/cmds/test_farm_cmd.py +1 -2
- chia/_tests/cmds/test_show.py +6 -6
- chia/_tests/cmds/test_tx_config_args.py +2 -1
- chia/_tests/cmds/wallet/test_dao.py +23 -23
- chia/_tests/cmds/wallet/test_did.py +29 -29
- chia/_tests/cmds/wallet/test_nft.py +24 -23
- chia/_tests/cmds/wallet/test_notifications.py +8 -8
- chia/_tests/cmds/wallet/test_tx_decorators.py +3 -3
- chia/_tests/cmds/wallet/test_vcs.py +97 -73
- chia/_tests/cmds/wallet/test_wallet.py +74 -75
- chia/_tests/cmds/wallet/test_wallet_check.py +5 -7
- chia/_tests/conftest.py +153 -38
- chia/_tests/connection_utils.py +7 -6
- chia/_tests/core/cmds/test_beta.py +3 -3
- chia/_tests/core/cmds/test_keys.py +6 -6
- chia/_tests/core/cmds/test_wallet.py +3 -3
- chia/_tests/core/consensus/test_block_creation.py +3 -5
- chia/_tests/core/custom_types/test_coin.py +1 -3
- chia/_tests/core/custom_types/test_spend_bundle.py +3 -4
- chia/_tests/core/daemon/test_daemon.py +58 -58
- chia/_tests/core/daemon/test_keychain_proxy.py +2 -1
- chia/_tests/core/data_layer/conftest.py +4 -3
- chia/_tests/core/data_layer/test_data_cli.py +1 -2
- chia/_tests/core/data_layer/test_data_layer.py +5 -5
- chia/_tests/core/data_layer/test_data_layer_util.py +8 -9
- chia/_tests/core/data_layer/test_data_rpc.py +75 -93
- chia/_tests/core/data_layer/test_data_store.py +38 -37
- chia/_tests/core/data_layer/test_data_store_schema.py +11 -11
- chia/_tests/core/data_layer/util.py +11 -10
- chia/_tests/core/farmer/test_farmer_api.py +6 -4
- chia/_tests/core/full_node/full_sync/test_full_sync.py +5 -10
- chia/_tests/core/full_node/ram_db.py +2 -2
- chia/_tests/core/full_node/stores/test_block_store.py +113 -11
- chia/_tests/core/full_node/stores/test_coin_store.py +37 -28
- chia/_tests/core/full_node/stores/test_full_node_store.py +34 -30
- chia/_tests/core/full_node/stores/test_hint_store.py +3 -4
- chia/_tests/core/full_node/test_address_manager.py +2 -2
- chia/_tests/core/full_node/test_block_height_map.py +1 -1
- chia/_tests/core/full_node/test_conditions.py +10 -12
- chia/_tests/core/full_node/test_full_node.py +2077 -1822
- chia/_tests/core/full_node/test_generator_tools.py +4 -4
- chia/_tests/core/full_node/test_hint_management.py +2 -2
- chia/_tests/core/full_node/test_performance.py +2 -5
- chia/_tests/core/full_node/test_subscriptions.py +4 -4
- chia/_tests/core/full_node/test_tx_processing_queue.py +5 -4
- chia/_tests/core/make_block_generator.py +5 -7
- chia/_tests/core/mempool/test_mempool.py +205 -208
- chia/_tests/core/mempool/test_mempool_fee_protocol.py +5 -5
- chia/_tests/core/mempool/test_mempool_item_queries.py +2 -4
- chia/_tests/core/mempool/test_mempool_manager.py +109 -80
- chia/_tests/core/mempool/test_mempool_performance.py +3 -4
- chia/_tests/core/mempool/test_singleton_fast_forward.py +12 -12
- chia/_tests/core/server/flood.py +6 -4
- chia/_tests/core/server/serve.py +10 -7
- chia/_tests/core/server/test_api_protocol.py +21 -0
- chia/_tests/core/server/test_capabilities.py +3 -5
- chia/_tests/core/server/test_dos.py +15 -16
- chia/_tests/core/server/test_loop.py +14 -10
- chia/_tests/core/server/test_node_discovery.py +1 -2
- chia/_tests/core/server/test_rate_limits.py +156 -44
- chia/_tests/core/server/test_server.py +8 -7
- chia/_tests/core/services/test_services.py +59 -37
- chia/_tests/core/ssl/test_ssl.py +5 -3
- chia/_tests/core/test_cost_calculation.py +5 -6
- chia/_tests/core/test_crawler.py +2 -2
- chia/_tests/core/test_db_conversion.py +5 -4
- chia/_tests/core/test_db_validation.py +6 -5
- chia/_tests/core/test_farmer_harvester_rpc.py +8 -7
- chia/_tests/core/test_filter.py +3 -5
- chia/_tests/core/test_full_node_rpc.py +64 -90
- chia/_tests/core/test_merkle_set.py +10 -10
- chia/_tests/core/test_program.py +2 -4
- chia/_tests/core/test_rpc_util.py +1 -2
- chia/_tests/core/test_seeder.py +124 -12
- chia/_tests/core/util/test_block_cache.py +5 -5
- chia/_tests/core/util/test_cached_bls.py +3 -3
- chia/_tests/core/util/test_config.py +13 -13
- chia/_tests/core/util/test_files.py +2 -2
- chia/_tests/core/util/test_jsonify.py +9 -9
- chia/_tests/core/util/test_keychain.py +13 -5
- chia/_tests/core/util/test_keyring_wrapper.py +6 -5
- chia/_tests/core/util/test_log_exceptions.py +3 -3
- chia/_tests/core/util/test_streamable.py +38 -38
- chia/_tests/db/test_db_wrapper.py +13 -12
- chia/_tests/environments/common.py +2 -2
- chia/_tests/environments/full_node.py +2 -2
- chia/_tests/environments/wallet.py +109 -48
- chia/_tests/farmer_harvester/test_farmer.py +35 -35
- chia/_tests/farmer_harvester/test_farmer_harvester.py +17 -17
- chia/_tests/farmer_harvester/test_filter_prefix_bits.py +6 -5
- chia/_tests/farmer_harvester/test_third_party_harvesters.py +73 -46
- chia/_tests/fee_estimation/test_fee_estimation_integration.py +8 -8
- chia/_tests/fee_estimation/test_fee_estimation_rpc.py +47 -47
- chia/_tests/fee_estimation/test_fee_estimation_unit_tests.py +6 -7
- chia/_tests/fee_estimation/test_mempoolitem_height_added.py +11 -11
- chia/_tests/generator/test_compression.py +13 -30
- chia/_tests/generator/test_generator_types.py +3 -3
- chia/_tests/generator/test_rom.py +7 -9
- chia/_tests/plot_sync/test_delta.py +2 -3
- chia/_tests/plot_sync/test_plot_sync.py +25 -24
- chia/_tests/plot_sync/test_receiver.py +9 -9
- chia/_tests/plot_sync/test_sender.py +1 -1
- chia/_tests/plot_sync/test_sync_simulated.py +27 -26
- chia/_tests/plot_sync/util.py +2 -1
- chia/_tests/plotting/test_plot_manager.py +54 -11
- chia/_tests/plotting/util.py +2 -3
- chia/_tests/pools/test_pool_cli_parsing.py +128 -0
- chia/_tests/pools/test_pool_cmdline.py +993 -15
- chia/_tests/pools/test_pool_config.py +3 -5
- chia/_tests/pools/test_pool_puzzles_lifecycle.py +10 -11
- chia/_tests/pools/test_pool_rpc.py +203 -90
- chia/_tests/pools/test_pool_wallet.py +12 -8
- chia/_tests/pools/test_wallet_pool_store.py +3 -3
- chia/_tests/process_junit.py +16 -17
- chia/_tests/rpc/test_rpc_client.py +59 -2
- chia/_tests/rpc/test_rpc_server.py +183 -0
- chia/_tests/simulation/test_simulation.py +5 -5
- chia/_tests/simulation/test_simulator.py +8 -10
- chia/_tests/simulation/test_start_simulator.py +5 -4
- chia/_tests/timelord/test_new_peak.py +19 -19
- chia/_tests/tools/test_run_block.py +1 -2
- chia/_tests/tools/test_virtual_project.py +591 -0
- chia/_tests/util/benchmark_cost.py +9 -9
- chia/_tests/util/benchmarks.py +1 -2
- chia/_tests/util/blockchain.py +12 -11
- chia/_tests/util/blockchain_mock.py +15 -15
- chia/_tests/util/build_network_protocol_files.py +12 -12
- chia/_tests/util/db_connection.py +3 -2
- chia/_tests/util/full_sync.py +14 -6
- chia/_tests/util/gen_ssl_certs.py +4 -5
- chia/_tests/util/generator_tools_testing.py +5 -7
- chia/_tests/util/get_name_puzzle_conditions.py +52 -0
- chia/_tests/util/key_tool.py +2 -3
- chia/_tests/util/misc.py +59 -106
- chia/_tests/util/network_protocol_data.py +7 -9
- chia/_tests/util/protocol_messages_json.py +112 -111
- chia/_tests/util/rpc.py +3 -0
- chia/_tests/util/run_block.py +16 -16
- chia/_tests/util/setup_nodes.py +25 -23
- chia/{clvm → _tests/util}/spend_sim.py +59 -55
- chia/_tests/util/split_managers.py +12 -9
- chia/_tests/util/temp_file.py +1 -1
- chia/_tests/util/test_action_scope.py +2 -1
- chia/_tests/util/test_async_pool.py +8 -8
- chia/_tests/util/test_build_job_matrix.py +2 -3
- chia/_tests/util/test_condition_tools.py +4 -6
- chia/_tests/util/test_config.py +5 -5
- chia/_tests/util/test_dump_keyring.py +1 -1
- chia/_tests/util/test_full_block_utils.py +19 -11
- chia/_tests/util/test_limited_semaphore.py +4 -3
- chia/_tests/util/test_logging_filter.py +2 -3
- chia/_tests/util/test_misc.py +29 -28
- chia/_tests/util/test_network.py +32 -31
- chia/_tests/util/test_network_protocol_files.py +2 -3
- chia/_tests/util/test_network_protocol_json.py +1 -0
- chia/_tests/util/test_network_protocol_test.py +18 -19
- chia/_tests/util/test_paginator.py +3 -4
- chia/_tests/util/test_pprint.py +1 -1
- chia/_tests/util/test_priority_mutex.py +18 -17
- chia/_tests/util/test_recursive_replace.py +2 -2
- chia/_tests/util/test_testnet_overrides.py +3 -3
- chia/_tests/util/test_timing.py +1 -1
- chia/_tests/util/test_trusted_peer.py +2 -2
- chia/_tests/util/time_out_assert.py +43 -6
- chia/_tests/wallet/cat_wallet/test_cat_lifecycle.py +13 -13
- chia/_tests/wallet/cat_wallet/test_cat_outer_puzzle.py +1 -1
- chia/_tests/wallet/cat_wallet/test_cat_wallet.py +117 -29
- chia/_tests/wallet/cat_wallet/test_offer_lifecycle.py +15 -15
- chia/_tests/wallet/cat_wallet/test_trades.py +50 -28
- chia/_tests/wallet/clawback/test_clawback_decorator.py +3 -5
- chia/_tests/wallet/clawback/test_clawback_lifecycle.py +6 -6
- chia/_tests/wallet/clawback/test_clawback_metadata.py +1 -2
- chia/_tests/wallet/conftest.py +135 -74
- chia/_tests/wallet/dao_wallet/test_dao_clvm.py +25 -17
- chia/_tests/wallet/dao_wallet/test_dao_wallets.py +75 -75
- chia/_tests/wallet/db_wallet/test_db_graftroot.py +10 -12
- chia/_tests/wallet/db_wallet/test_dl_offers.py +6 -6
- chia/_tests/wallet/db_wallet/test_dl_wallet.py +18 -18
- chia/_tests/wallet/did_wallet/test_did.py +1277 -474
- chia/_tests/wallet/nft_wallet/test_nft_1_offers.py +12 -11
- chia/_tests/wallet/nft_wallet/test_nft_bulk_mint.py +115 -105
- chia/_tests/wallet/nft_wallet/test_nft_lifecycle.py +6 -7
- chia/_tests/wallet/nft_wallet/test_nft_offers.py +16 -16
- chia/_tests/wallet/nft_wallet/test_nft_puzzles.py +3 -3
- chia/_tests/wallet/nft_wallet/test_nft_wallet.py +38 -12
- chia/_tests/wallet/nft_wallet/test_ownership_outer_puzzle.py +1 -1
- chia/_tests/wallet/rpc/test_dl_wallet_rpc.py +31 -33
- chia/_tests/wallet/rpc/test_wallet_rpc.py +218 -171
- chia/_tests/wallet/simple_sync/test_simple_sync_protocol.py +36 -37
- chia/_tests/wallet/sync/test_wallet_sync.py +241 -78
- chia/_tests/wallet/test_address_type.py +20 -20
- chia/_tests/wallet/test_clvm_streamable.py +5 -5
- chia/_tests/wallet/test_coin_management.py +354 -0
- chia/_tests/wallet/test_coin_selection.py +34 -35
- chia/_tests/wallet/test_conditions.py +28 -16
- chia/_tests/wallet/test_debug_spend_bundle.py +156 -14
- chia/_tests/wallet/test_new_wallet_protocol.py +29 -31
- chia/_tests/wallet/test_nft_store.py +1 -2
- chia/_tests/wallet/test_notifications.py +2 -2
- chia/_tests/wallet/test_offer_parsing_performance.py +1 -1
- chia/_tests/wallet/test_puzzle_store.py +2 -3
- chia/_tests/wallet/test_sign_coin_spends.py +3 -3
- chia/_tests/wallet/test_signer_protocol.py +33 -34
- chia/_tests/wallet/test_singleton_lifecycle_fast.py +29 -29
- chia/_tests/wallet/test_taproot.py +1 -1
- chia/_tests/wallet/test_transaction_store.py +23 -19
- chia/_tests/wallet/test_util.py +36 -32
- chia/_tests/wallet/test_wallet.py +37 -37
- chia/_tests/wallet/test_wallet_action_scope.py +8 -8
- chia/_tests/wallet/test_wallet_blockchain.py +4 -6
- chia/_tests/wallet/test_wallet_coin_store.py +34 -34
- chia/_tests/wallet/test_wallet_node.py +69 -72
- chia/_tests/wallet/test_wallet_retry.py +3 -3
- chia/_tests/wallet/test_wallet_state_manager.py +12 -5
- chia/_tests/wallet/test_wallet_trade_store.py +2 -2
- chia/_tests/wallet/test_wallet_utils.py +5 -4
- chia/_tests/wallet/vc_wallet/test_cr_outer_puzzle.py +3 -3
- chia/_tests/wallet/vc_wallet/test_vc_lifecycle.py +18 -18
- chia/_tests/wallet/vc_wallet/test_vc_wallet.py +69 -40
- chia/_tests/wallet/wallet_block_tools.py +27 -27
- chia/_tests/weight_proof/test_weight_proof.py +30 -30
- chia/apis.py +19 -0
- chia/cmds/beta.py +8 -7
- chia/cmds/beta_funcs.py +15 -11
- chia/cmds/check_wallet_db.py +29 -27
- chia/cmds/chia.py +17 -9
- chia/cmds/cmd_classes.py +87 -79
- chia/cmds/cmd_helpers.py +242 -0
- chia/cmds/cmds_util.py +56 -66
- chia/cmds/coin_funcs.py +168 -153
- chia/cmds/coins.py +156 -194
- chia/cmds/configure.py +4 -3
- chia/cmds/dao.py +89 -33
- chia/cmds/dao_funcs.py +55 -33
- chia/cmds/data.py +7 -6
- chia/cmds/data_funcs.py +26 -21
- chia/cmds/db.py +4 -3
- chia/cmds/db_backup_func.py +2 -2
- chia/cmds/db_upgrade_func.py +3 -3
- chia/cmds/db_validate_func.py +2 -2
- chia/cmds/dev.py +2 -0
- chia/cmds/farm.py +18 -5
- chia/cmds/farm_funcs.py +17 -24
- chia/cmds/gh.py +275 -0
- chia/cmds/init.py +4 -11
- chia/cmds/init_funcs.py +9 -9
- chia/cmds/installers.py +5 -3
- chia/cmds/keys.py +56 -39
- chia/cmds/keys_funcs.py +30 -31
- chia/cmds/netspace.py +6 -3
- chia/cmds/netspace_funcs.py +3 -2
- chia/cmds/param_types.py +16 -6
- chia/cmds/passphrase.py +8 -7
- chia/cmds/passphrase_funcs.py +7 -61
- chia/cmds/peer.py +2 -1
- chia/cmds/peer_funcs.py +5 -5
- chia/cmds/plotnft.py +207 -153
- chia/cmds/plotnft_funcs.py +205 -174
- chia/cmds/plots.py +14 -6
- chia/cmds/plotters.py +2 -1
- chia/cmds/rpc.py +48 -28
- chia/cmds/show.py +2 -1
- chia/cmds/show_funcs.py +7 -6
- chia/cmds/signer.py +50 -58
- chia/cmds/sim.py +22 -14
- chia/cmds/sim_funcs.py +11 -11
- chia/cmds/start.py +3 -3
- chia/cmds/start_funcs.py +9 -12
- chia/cmds/stop.py +4 -3
- chia/cmds/units.py +1 -3
- chia/cmds/wallet.py +252 -96
- chia/cmds/wallet_funcs.py +217 -143
- chia/consensus/block_body_validation.py +133 -86
- chia/consensus/block_creation.py +42 -21
- chia/consensus/block_header_validation.py +32 -37
- chia/consensus/block_record.py +1 -2
- chia/consensus/blockchain.py +167 -180
- chia/consensus/blockchain_interface.py +10 -10
- chia/consensus/constants.py +2 -2
- chia/consensus/default_constants.py +3 -4
- chia/consensus/difficulty_adjustment.py +5 -5
- chia/consensus/find_fork_point.py +5 -5
- chia/consensus/full_block_to_block_record.py +4 -4
- chia/consensus/get_block_challenge.py +2 -2
- chia/consensus/get_block_generator.py +4 -3
- chia/consensus/multiprocess_validation.py +207 -304
- chia/consensus/vdf_info_computation.py +3 -3
- chia/daemon/client.py +46 -27
- chia/daemon/keychain_proxy.py +10 -9
- chia/daemon/keychain_server.py +18 -18
- chia/daemon/server.py +103 -113
- chia/daemon/windows_signal.py +2 -2
- chia/data_layer/data_layer.py +64 -76
- chia/data_layer/data_layer_api.py +8 -0
- chia/data_layer/data_layer_errors.py +3 -3
- chia/data_layer/data_layer_server.py +2 -2
- chia/data_layer/data_layer_util.py +71 -71
- chia/data_layer/data_layer_wallet.py +63 -67
- chia/data_layer/data_store.py +72 -72
- chia/data_layer/dl_wallet_store.py +10 -10
- chia/data_layer/download_data.py +5 -5
- chia/data_layer/s3_plugin_service.py +9 -9
- chia/data_layer/util/benchmark.py +0 -1
- chia/data_layer/util/plugin.py +2 -3
- chia/farmer/farmer.py +46 -43
- chia/farmer/farmer_api.py +27 -21
- chia/full_node/block_height_map.py +6 -6
- chia/full_node/block_store.py +41 -35
- chia/full_node/coin_store.py +42 -41
- chia/full_node/fee_estimate.py +2 -2
- chia/full_node/fee_estimation.py +1 -2
- chia/full_node/fee_history.py +5 -6
- chia/full_node/fee_tracker.py +24 -24
- chia/full_node/full_node.py +574 -300
- chia/full_node/full_node_api.py +181 -130
- chia/full_node/full_node_store.py +43 -43
- chia/full_node/hint_management.py +4 -4
- chia/full_node/hint_store.py +9 -10
- chia/full_node/mempool.py +25 -19
- chia/full_node/mempool_check_conditions.py +11 -42
- chia/full_node/mempool_manager.py +48 -53
- chia/full_node/pending_tx_cache.py +9 -9
- chia/full_node/subscriptions.py +23 -24
- chia/full_node/sync_store.py +8 -7
- chia/full_node/tx_processing_queue.py +3 -3
- chia/full_node/util/__init__.py +0 -0
- chia/full_node/weight_proof.py +79 -78
- chia/harvester/harvester.py +9 -8
- chia/harvester/harvester_api.py +19 -13
- chia/introducer/introducer.py +7 -5
- chia/introducer/introducer_api.py +9 -3
- chia/legacy/keyring.py +6 -5
- chia/plot_sync/delta.py +8 -8
- chia/plot_sync/receiver.py +12 -11
- chia/plot_sync/sender.py +15 -12
- chia/plotters/bladebit.py +12 -12
- chia/plotters/chiapos.py +2 -2
- chia/plotters/madmax.py +8 -8
- chia/plotters/plotters.py +6 -6
- chia/plotters/plotters_util.py +6 -4
- chia/plotting/cache.py +8 -7
- chia/plotting/check_plots.py +8 -8
- chia/plotting/create_plots.py +6 -6
- chia/plotting/manager.py +22 -22
- chia/plotting/util.py +31 -19
- chia/pools/pool_config.py +7 -7
- chia/pools/pool_puzzles.py +16 -16
- chia/pools/pool_wallet.py +64 -57
- chia/pools/pool_wallet_info.py +3 -3
- chia/protocols/full_node_protocol.py +3 -3
- chia/protocols/harvester_protocol.py +12 -12
- chia/protocols/introducer_protocol.py +1 -2
- chia/protocols/protocol_message_types.py +4 -4
- chia/protocols/protocol_state_machine.py +2 -2
- chia/protocols/protocol_timing.py +1 -0
- chia/protocols/shared_protocol.py +3 -3
- chia/protocols/timelord_protocol.py +2 -2
- chia/protocols/wallet_protocol.py +33 -33
- chia/rpc/crawler_rpc_api.py +12 -7
- chia/rpc/data_layer_rpc_api.py +49 -44
- chia/rpc/data_layer_rpc_client.py +41 -41
- chia/rpc/data_layer_rpc_util.py +7 -11
- chia/rpc/farmer_rpc_api.py +32 -27
- chia/rpc/farmer_rpc_client.py +14 -14
- chia/rpc/full_node_rpc_api.py +53 -48
- chia/rpc/full_node_rpc_client.py +30 -30
- chia/rpc/harvester_rpc_api.py +16 -11
- chia/rpc/harvester_rpc_client.py +6 -6
- chia/rpc/rpc_client.py +34 -14
- chia/rpc/rpc_server.py +117 -43
- chia/rpc/timelord_rpc_api.py +9 -4
- chia/rpc/util.py +11 -211
- chia/rpc/wallet_request_types.py +276 -60
- chia/rpc/wallet_rpc_api.py +563 -399
- chia/rpc/wallet_rpc_client.py +220 -250
- chia/seeder/crawl_store.py +6 -8
- chia/seeder/crawler.py +23 -36
- chia/seeder/crawler_api.py +28 -22
- chia/seeder/dns_server.py +99 -50
- chia/seeder/start_crawler.py +13 -9
- chia/server/address_manager.py +19 -19
- chia/server/address_manager_store.py +17 -17
- chia/server/api_protocol.py +106 -1
- chia/server/capabilities.py +3 -3
- chia/server/chia_policy.py +17 -16
- chia/server/introducer_peers.py +3 -3
- chia/server/node_discovery.py +34 -38
- chia/server/rate_limit_numbers.py +26 -16
- chia/server/rate_limits.py +67 -27
- chia/server/server.py +52 -31
- chia/server/signal_handlers.py +6 -3
- chia/server/ssl_context.py +5 -5
- chia/server/start_data_layer.py +37 -23
- chia/server/start_farmer.py +28 -16
- chia/server/start_full_node.py +29 -23
- chia/server/start_harvester.py +28 -15
- chia/server/start_introducer.py +27 -15
- chia/server/start_service.py +17 -29
- chia/server/start_timelord.py +25 -18
- chia/server/start_wallet.py +22 -18
- chia/server/upnp.py +4 -3
- chia/server/ws_connection.py +68 -54
- chia/simulator/add_blocks_in_batches.py +54 -0
- chia/simulator/block_tools.py +65 -64
- chia/simulator/full_node_simulator.py +66 -74
- chia/simulator/setup_services.py +10 -9
- chia/simulator/simulator_full_node_rpc_api.py +12 -14
- chia/simulator/simulator_full_node_rpc_client.py +3 -5
- chia/simulator/simulator_test_tools.py +8 -7
- chia/simulator/socket.py +1 -4
- chia/simulator/ssl_certs.py +5 -5
- chia/simulator/ssl_certs_1.py +2 -4
- chia/simulator/ssl_certs_10.py +2 -4
- chia/simulator/ssl_certs_2.py +2 -4
- chia/simulator/ssl_certs_3.py +2 -4
- chia/simulator/ssl_certs_4.py +2 -4
- chia/simulator/ssl_certs_5.py +2 -4
- chia/simulator/ssl_certs_6.py +2 -4
- chia/simulator/ssl_certs_7.py +2 -4
- chia/simulator/ssl_certs_8.py +2 -4
- chia/simulator/ssl_certs_9.py +2 -4
- chia/simulator/start_simulator.py +14 -6
- chia/simulator/wallet_tools.py +21 -20
- chia/ssl/create_ssl.py +11 -11
- chia/timelord/iters_from_block.py +2 -2
- chia/timelord/timelord.py +57 -33
- chia/timelord/timelord_api.py +12 -6
- chia/timelord/timelord_launcher.py +10 -8
- chia/timelord/timelord_state.py +5 -5
- chia/types/block_protocol.py +2 -2
- chia/types/blockchain_format/coin.py +3 -3
- chia/types/blockchain_format/program.py +17 -18
- chia/types/blockchain_format/tree_hash.py +9 -9
- chia/types/coin_spend.py +8 -8
- chia/types/condition_with_args.py +1 -2
- chia/types/eligible_coin_spends.py +16 -15
- chia/types/generator_types.py +1 -2
- chia/types/internal_mempool_item.py +1 -2
- chia/types/mempool_item.py +7 -7
- chia/types/mempool_submission_status.py +2 -2
- chia/types/peer_info.py +1 -1
- chia/types/spend_bundle.py +1 -2
- chia/types/transaction_queue_entry.py +2 -2
- chia/types/unfinished_header_block.py +2 -2
- chia/types/validation_state.py +14 -0
- chia/types/weight_proof.py +5 -6
- chia/util/action_scope.py +8 -8
- chia/util/async_pool.py +6 -4
- chia/util/augmented_chain.py +13 -9
- chia/util/batches.py +5 -2
- chia/util/bech32m.py +14 -11
- chia/util/beta_metrics.py +5 -4
- chia/util/block_cache.py +5 -5
- chia/util/byte_types.py +2 -0
- chia/util/check_fork_next_block.py +3 -2
- chia/util/chia_logging.py +41 -21
- chia/util/collection.py +3 -3
- chia/util/condition_tools.py +18 -18
- chia/util/config.py +26 -25
- chia/util/cpu.py +2 -0
- chia/util/db_synchronous.py +2 -0
- chia/util/db_version.py +2 -0
- chia/util/db_wrapper.py +13 -10
- chia/util/default_root.py +17 -0
- chia/util/dump_keyring.py +6 -6
- chia/util/errors.py +5 -3
- chia/util/file_keyring.py +22 -33
- chia/util/files.py +2 -0
- chia/util/full_block_utils.py +31 -7
- chia/util/generator_tools.py +18 -8
- chia/util/hash.py +3 -1
- chia/util/initial-config.yaml +19 -0
- chia/util/inline_executor.py +2 -0
- chia/util/ip_address.py +39 -0
- chia/util/json_util.py +0 -4
- chia/util/keychain.py +27 -24
- chia/util/keyring_wrapper.py +65 -4
- chia/util/limited_semaphore.py +3 -1
- chia/util/lock.py +4 -2
- chia/util/log_exceptions.py +5 -2
- chia/util/logging.py +3 -1
- chia/util/lru_cache.py +2 -0
- chia/util/math.py +4 -4
- chia/util/network.py +15 -73
- chia/util/paginator.py +3 -1
- chia/util/path.py +2 -0
- chia/util/permissions.py +3 -2
- chia/util/prev_transaction_block.py +1 -3
- chia/util/priority_mutex.py +6 -3
- chia/util/profiler.py +7 -4
- chia/util/recursive_replace.py +2 -0
- chia/util/safe_cancel_task.py +2 -0
- chia/util/service_groups.py +2 -2
- chia/util/setproctitle.py +2 -0
- chia/util/significant_bits.py +2 -0
- chia/util/ssl_check.py +11 -11
- chia/util/streamable.py +44 -56
- chia/util/task_referencer.py +59 -0
- chia/util/task_timing.py +22 -18
- chia/util/timing.py +4 -1
- chia/util/vdf_prover.py +2 -3
- chia/util/virtual_project_analysis.py +540 -0
- chia/util/ws_message.py +6 -6
- chia/wallet/cat_wallet/cat_info.py +3 -3
- chia/wallet/cat_wallet/cat_outer_puzzle.py +3 -3
- chia/wallet/cat_wallet/cat_utils.py +5 -4
- chia/wallet/cat_wallet/cat_wallet.py +56 -70
- chia/wallet/cat_wallet/dao_cat_info.py +3 -3
- chia/wallet/cat_wallet/dao_cat_wallet.py +18 -18
- chia/wallet/cat_wallet/lineage_store.py +2 -2
- chia/wallet/coin_selection.py +15 -15
- chia/wallet/conditions.py +257 -71
- chia/wallet/dao_wallet/dao_info.py +4 -4
- chia/wallet/dao_wallet/dao_utils.py +43 -42
- chia/wallet/dao_wallet/dao_wallet.py +66 -68
- chia/wallet/db_wallet/db_wallet_puzzles.py +12 -8
- chia/wallet/derive_keys.py +11 -11
- chia/wallet/did_wallet/did_info.py +3 -3
- chia/wallet/did_wallet/did_wallet.py +56 -47
- chia/wallet/did_wallet/did_wallet_puzzles.py +7 -6
- chia/wallet/lineage_proof.py +4 -4
- chia/wallet/nft_wallet/metadata_outer_puzzle.py +2 -2
- chia/wallet/nft_wallet/nft_info.py +4 -4
- chia/wallet/nft_wallet/nft_puzzles.py +16 -16
- chia/wallet/nft_wallet/nft_wallet.py +90 -89
- chia/wallet/nft_wallet/ownership_outer_puzzle.py +2 -2
- chia/wallet/nft_wallet/singleton_outer_puzzle.py +2 -2
- chia/wallet/nft_wallet/transfer_program_puzzle.py +2 -2
- chia/wallet/nft_wallet/uncurry_nft.py +2 -2
- chia/wallet/notification_manager.py +5 -5
- chia/wallet/notification_store.py +6 -6
- chia/wallet/outer_puzzles.py +2 -2
- chia/wallet/payment.py +4 -5
- chia/wallet/puzzle_drivers.py +4 -4
- chia/wallet/puzzles/clawback/drivers.py +5 -5
- chia/wallet/puzzles/clawback/puzzle_decorator.py +7 -7
- chia/wallet/puzzles/load_clvm.py +2 -3
- chia/wallet/puzzles/p2_conditions.py +1 -2
- chia/wallet/puzzles/p2_delegated_conditions.py +1 -2
- chia/wallet/puzzles/p2_delegated_puzzle.py +2 -3
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.py +3 -4
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.py +1 -2
- chia/wallet/puzzles/p2_puzzle_hash.py +1 -2
- chia/wallet/puzzles/puzzle_utils.py +7 -7
- chia/wallet/puzzles/singleton_top_layer.py +6 -5
- chia/wallet/puzzles/singleton_top_layer_v1_1.py +6 -5
- chia/wallet/puzzles/tails.py +34 -30
- chia/wallet/signer_protocol.py +7 -8
- chia/wallet/singleton.py +4 -4
- chia/wallet/trade_manager.py +155 -141
- chia/wallet/trade_record.py +5 -5
- chia/wallet/trading/offer.py +100 -101
- chia/wallet/trading/trade_store.py +14 -14
- chia/wallet/transaction_record.py +31 -16
- chia/wallet/util/address_type.py +4 -4
- chia/wallet/util/blind_signer_tl.py +8 -12
- chia/wallet/util/clvm_streamable.py +15 -15
- chia/wallet/util/compute_hints.py +5 -5
- chia/wallet/util/compute_memos.py +4 -6
- chia/wallet/util/curry_and_treehash.py +3 -2
- chia/wallet/util/debug_spend_bundle.py +6 -8
- chia/wallet/util/merkle_tree.py +10 -10
- chia/wallet/util/merkle_utils.py +10 -10
- chia/wallet/util/new_peak_queue.py +3 -3
- chia/wallet/util/peer_request_cache.py +8 -8
- chia/{util → wallet/util}/pprint.py +2 -3
- chia/wallet/util/puzzle_compression.py +3 -4
- chia/wallet/util/puzzle_decorator.py +10 -10
- chia/wallet/util/query_filter.py +9 -10
- chia/wallet/util/tx_config.py +12 -12
- chia/wallet/util/wallet_sync_utils.py +24 -21
- chia/wallet/util/wallet_types.py +9 -2
- chia/wallet/vc_wallet/cr_cat_drivers.py +28 -27
- chia/wallet/vc_wallet/cr_cat_wallet.py +42 -40
- chia/wallet/vc_wallet/cr_outer_puzzle.py +4 -4
- chia/wallet/vc_wallet/vc_drivers.py +16 -16
- chia/wallet/vc_wallet/vc_store.py +9 -9
- chia/wallet/vc_wallet/vc_wallet.py +35 -35
- chia/wallet/wallet.py +54 -54
- chia/wallet/wallet_action_scope.py +14 -13
- chia/wallet/wallet_blockchain.py +10 -10
- chia/wallet/wallet_coin_record.py +2 -2
- chia/wallet/wallet_coin_store.py +10 -10
- chia/wallet/wallet_info.py +1 -2
- chia/wallet/wallet_interested_store.py +5 -5
- chia/wallet/wallet_nft_store.py +6 -6
- chia/wallet/wallet_node.py +72 -76
- chia/wallet/wallet_node_api.py +33 -27
- chia/wallet/wallet_pool_store.py +1 -2
- chia/wallet/wallet_protocol.py +15 -15
- chia/wallet/wallet_puzzle_store.py +35 -4
- chia/wallet/wallet_retry_store.py +2 -2
- chia/wallet/wallet_singleton_store.py +10 -9
- chia/wallet/wallet_spend_bundle.py +4 -20
- chia/wallet/wallet_state_manager.py +223 -224
- chia/wallet/wallet_transaction_store.py +44 -18
- chia/wallet/wallet_user_store.py +2 -2
- chia/wallet/wallet_weight_proof_handler.py +2 -2
- {chia_blockchain-2.5.0rc2.dist-info → chia_blockchain-2.5.1rc2.dist-info}/LICENSE +1 -1
- {chia_blockchain-2.5.0rc2.dist-info → chia_blockchain-2.5.1rc2.dist-info}/METADATA +67 -72
- chia_blockchain-2.5.1rc2.dist-info/RECORD +1042 -0
- {chia_blockchain-2.5.0rc2.dist-info → chia_blockchain-2.5.1rc2.dist-info}/WHEEL +1 -1
- mozilla-ca/cacert.pem +32 -87
- chia/_tests/cmds/wallet/test_coins.py +0 -195
- chia/consensus/block_root_validation.py +0 -46
- chia/util/api_decorators.py +0 -89
- chia_blockchain-2.5.0rc2.dist-info/RECORD +0 -1028
- {chia_blockchain-2.5.0rc2.dist-info → chia_blockchain-2.5.1rc2.dist-info}/entry_points.txt +0 -0
chia/simulator/ssl_certs.py
CHANGED
|
@@ -2,7 +2,7 @@ from __future__ import annotations
|
|
|
2
2
|
|
|
3
3
|
import itertools
|
|
4
4
|
from dataclasses import dataclass, field
|
|
5
|
-
from typing import
|
|
5
|
+
from typing import Generic, TypeVar
|
|
6
6
|
|
|
7
7
|
from chia.simulator.ssl_certs_1 import SSL_TEST_NODE_CERTS_AND_KEYS_1, SSL_TEST_PRIVATE_CA_CERT_AND_KEY_1
|
|
8
8
|
from chia.simulator.ssl_certs_2 import SSL_TEST_NODE_CERTS_AND_KEYS_2, SSL_TEST_PRIVATE_CA_CERT_AND_KEY_2
|
|
@@ -39,12 +39,12 @@ class SSLTestCollateralTracker:
|
|
|
39
39
|
|
|
40
40
|
@dataclass
|
|
41
41
|
class SSLTestCACertAndPrivateKey(SSLTestCollateralTracker):
|
|
42
|
-
cert_and_key:
|
|
42
|
+
cert_and_key: tuple[bytes, bytes]
|
|
43
43
|
|
|
44
44
|
|
|
45
45
|
@dataclass
|
|
46
46
|
class SSLTestNodeCertsAndKeys(SSLTestCollateralTracker):
|
|
47
|
-
certs_and_keys:
|
|
47
|
+
certs_and_keys: dict[str, dict[str, dict[str, bytes]]]
|
|
48
48
|
|
|
49
49
|
|
|
50
50
|
@dataclass
|
|
@@ -64,7 +64,7 @@ class SSLTestCollateralWrapper(Generic[_T_SSLTestCollateral]):
|
|
|
64
64
|
# Private CA certs/keys
|
|
65
65
|
# ---------------------------------------------------------------------------
|
|
66
66
|
|
|
67
|
-
SSL_TEST_PRIVATE_CA_CERTS_AND_KEYS:
|
|
67
|
+
SSL_TEST_PRIVATE_CA_CERTS_AND_KEYS: list[SSLTestCACertAndPrivateKey] = [
|
|
68
68
|
SSLTestCACertAndPrivateKey(SSL_TEST_PRIVATE_CA_CERT_AND_KEY_1),
|
|
69
69
|
SSLTestCACertAndPrivateKey(SSL_TEST_PRIVATE_CA_CERT_AND_KEY_2),
|
|
70
70
|
SSLTestCACertAndPrivateKey(SSL_TEST_PRIVATE_CA_CERT_AND_KEY_3),
|
|
@@ -81,7 +81,7 @@ SSL_TEST_PRIVATE_CA_CERTS_AND_KEYS: List[SSLTestCACertAndPrivateKey] = [
|
|
|
81
81
|
# Node -> cert/key mappings
|
|
82
82
|
# ---------------------------------------------------------------------------
|
|
83
83
|
|
|
84
|
-
SSL_TEST_NODE_CERTS_AND_KEYS:
|
|
84
|
+
SSL_TEST_NODE_CERTS_AND_KEYS: list[SSLTestNodeCertsAndKeys] = [
|
|
85
85
|
SSLTestNodeCertsAndKeys(SSL_TEST_NODE_CERTS_AND_KEYS_1),
|
|
86
86
|
SSLTestNodeCertsAndKeys(SSL_TEST_NODE_CERTS_AND_KEYS_2),
|
|
87
87
|
SSLTestNodeCertsAndKeys(SSL_TEST_NODE_CERTS_AND_KEYS_3),
|
chia/simulator/ssl_certs_1.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUZnoqyaLGQMl08azdwpafGGfEGR0wDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ NR6RKo206k2HeqrAQC0L0A==
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_1:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_1: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_1:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_1: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_10.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUWzGLmUq3RgS/u2oYomRSyKsXWwcwDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ EMu0jkyvnFmDWG65WRzbD5c=
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_10:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_10: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_10:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_10: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_2.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUbFhRlgpIM3M+ZYuTigQ1Vbmi6P4wDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ y5AZoW69GqwC41YzBDIO0w==
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_2:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_2: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_2:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_2: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_3.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUeLxDdxR+RmiMMvvCxRfsQJAL7vUwDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ p0weDMN6dQd5dKE+pUZYYpM=
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_3:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_3: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_3:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_3: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_4.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUS+xy2kGNomsBGfU0DEELWiHoSa4wDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ d8a1rEOCndTj7T9DNTBfYl0=
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_4:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_4: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_4:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_4: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_5.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUXU/nGxb+rZck2qIMztmDWKDZCBcwDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ gqCQGe9wW+ZeGMo5qplhtJURjus=
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_5:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_5: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_5:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_5: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_6.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUD5VUdvJQlRhGJg2WJ+/K8I2sYZcwDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ NCqsxWTlPvhxmdJj/TVownPJrzA=
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_6:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_6: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_6:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_6: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_7.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUHoeobLQu3yMmraIDXDF+F6M4j9IwDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ QSJ3WfEjOC9Xe5CR6qPEmR99
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_7:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_7: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_7:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_7: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_8.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUaAgNa9r45P7lGSz9yjEAMmSYuA4wDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ axack/6KTJBo6FRskxPoH4U=
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_8:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_8: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_8:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_8: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
chia/simulator/ssl_certs_9.py
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Dict, Tuple
|
|
4
|
-
|
|
5
3
|
SSL_TEST_PRIVATE_CA_CRT = b"""-----BEGIN CERTIFICATE-----
|
|
6
4
|
MIIDKTCCAhGgAwIBAgIUX9kvHEjir5fniTg3GRQ8wO7zOvAwDQYJKoZIhvcNAQEL
|
|
7
5
|
BQAwRDENMAsGA1UECgwEQ2hpYTEQMA4GA1UEAwwHQ2hpYSBDQTEhMB8GA1UECwwY
|
|
@@ -665,9 +663,9 @@ P3vN0OIo1UZaNRW6CpZLa8sOyg==
|
|
|
665
663
|
-----END PRIVATE KEY-----
|
|
666
664
|
"""
|
|
667
665
|
|
|
668
|
-
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_9:
|
|
666
|
+
SSL_TEST_PRIVATE_CA_CERT_AND_KEY_9: tuple[bytes, bytes] = (SSL_TEST_PRIVATE_CA_CRT, SSL_TEST_PRIVATE_CA_KEY)
|
|
669
667
|
|
|
670
|
-
SSL_TEST_NODE_CERTS_AND_KEYS_9:
|
|
668
|
+
SSL_TEST_NODE_CERTS_AND_KEYS_9: dict[str, dict[str, dict[str, bytes]]] = {
|
|
671
669
|
"full_node": {
|
|
672
670
|
"private": {"crt": SSL_TEST_FULLNODE_PRIVATE_CRT, "key": SSL_TEST_FULLNODE_PRIVATE_KEY},
|
|
673
671
|
"public": {"crt": SSL_TEST_FULLNODE_PUBLIC_CRT, "key": SSL_TEST_FULLNODE_PUBLIC_KEY},
|
|
@@ -5,8 +5,9 @@ import sys
|
|
|
5
5
|
from dataclasses import dataclass
|
|
6
6
|
from multiprocessing import freeze_support
|
|
7
7
|
from pathlib import Path
|
|
8
|
-
from typing import Any,
|
|
8
|
+
from typing import Any, Optional
|
|
9
9
|
|
|
10
|
+
from chia.apis import ApiProtocolRegistry
|
|
10
11
|
from chia.full_node.full_node import FullNode
|
|
11
12
|
from chia.server.outbound_message import NodeType
|
|
12
13
|
from chia.server.signal_handlers import SignalHandlers
|
|
@@ -18,7 +19,7 @@ from chia.types.blockchain_format.sized_bytes import bytes32
|
|
|
18
19
|
from chia.util.bech32m import decode_puzzle_hash
|
|
19
20
|
from chia.util.chia_logging import initialize_logging
|
|
20
21
|
from chia.util.config import load_config, load_config_cli, override_config
|
|
21
|
-
from chia.util.default_root import
|
|
22
|
+
from chia.util.default_root import resolve_root_path
|
|
22
23
|
from chia.util.ints import uint16
|
|
23
24
|
|
|
24
25
|
SimulatorFullNodeService = Service[FullNode, FullNodeSimulator, SimulatorFullNodeRpcApi]
|
|
@@ -34,10 +35,10 @@ PLOT_SIZE = 19 # anything under k19 is a bit buggy
|
|
|
34
35
|
|
|
35
36
|
async def create_full_node_simulator_service(
|
|
36
37
|
root_path: Path,
|
|
37
|
-
config:
|
|
38
|
+
config: dict[str, Any],
|
|
38
39
|
bt: BlockTools,
|
|
39
40
|
connect_to_daemon: bool = True,
|
|
40
|
-
override_capabilities: Optional[
|
|
41
|
+
override_capabilities: Optional[list[tuple[uint16, str]]] = None,
|
|
41
42
|
) -> SimulatorFullNodeService:
|
|
42
43
|
service_config = config[SERVICE_NAME]
|
|
43
44
|
constants = bt.constants
|
|
@@ -63,6 +64,7 @@ async def create_full_node_simulator_service(
|
|
|
63
64
|
rpc_info=(SimulatorFullNodeRpcApi, service_config["rpc_port"]),
|
|
64
65
|
connect_to_daemon=connect_to_daemon,
|
|
65
66
|
override_capabilities=override_capabilities,
|
|
67
|
+
class_for_type=ApiProtocolRegistry,
|
|
66
68
|
)
|
|
67
69
|
|
|
68
70
|
|
|
@@ -75,8 +77,12 @@ class StartedSimulator:
|
|
|
75
77
|
async def async_main(
|
|
76
78
|
test_mode: bool = False,
|
|
77
79
|
automated_testing: bool = False,
|
|
78
|
-
root_path: Path =
|
|
80
|
+
root_path: Optional[Path] = None,
|
|
79
81
|
) -> StartedSimulator:
|
|
82
|
+
root_path = resolve_root_path(override=root_path)
|
|
83
|
+
# helping mypy out for now
|
|
84
|
+
assert root_path is not None
|
|
85
|
+
|
|
80
86
|
# Same as full node, but the root_path is defined above
|
|
81
87
|
config = load_config(root_path, "config.yaml")
|
|
82
88
|
service_config = load_config_cli(root_path, "config.yaml", SERVICE_NAME)
|
|
@@ -128,7 +134,9 @@ async def async_main(
|
|
|
128
134
|
|
|
129
135
|
def main() -> int:
|
|
130
136
|
freeze_support()
|
|
131
|
-
|
|
137
|
+
root_path = resolve_root_path(override=None)
|
|
138
|
+
|
|
139
|
+
return async_run(async_main(root_path=root_path)).exit_code
|
|
132
140
|
|
|
133
141
|
|
|
134
142
|
if __name__ == "__main__":
|
chia/simulator/wallet_tools.py
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Any,
|
|
3
|
+
from typing import Any, Optional
|
|
4
4
|
|
|
5
5
|
from chia_rs import AugSchemeMPL, G1Element, G2Element, PrivateKey
|
|
6
6
|
from clvm.casts import int_from_bytes, int_to_bytes
|
|
@@ -32,8 +32,9 @@ assert len(DEFAULT_SEED) == 32
|
|
|
32
32
|
|
|
33
33
|
class WalletTool:
|
|
34
34
|
next_address = 0
|
|
35
|
-
|
|
36
|
-
|
|
35
|
+
# TODO: make this a dataclass to make these instance attributes instead of mutable class attributes
|
|
36
|
+
pubkey_num_lookup: dict[bytes, uint32] = {} # noqa: RUF012
|
|
37
|
+
puzzle_pk_cache: dict[bytes32, PrivateKey] = {} # noqa: RUF012
|
|
37
38
|
|
|
38
39
|
def __init__(self, constants: ConsensusConstants, sk: Optional[PrivateKey] = None):
|
|
39
40
|
self.constants = constants
|
|
@@ -43,8 +44,8 @@ class WalletTool:
|
|
|
43
44
|
self.private_key = sk
|
|
44
45
|
else:
|
|
45
46
|
self.private_key = AugSchemeMPL.key_gen(DEFAULT_SEED)
|
|
46
|
-
self.generator_lookups:
|
|
47
|
-
self.puzzle_pk_cache:
|
|
47
|
+
self.generator_lookups: dict = {}
|
|
48
|
+
self.puzzle_pk_cache: dict = {}
|
|
48
49
|
self.get_new_puzzle()
|
|
49
50
|
|
|
50
51
|
def get_next_address_index(self) -> uint32:
|
|
@@ -83,31 +84,31 @@ class WalletTool:
|
|
|
83
84
|
privatekey: PrivateKey = master_sk_to_wallet_sk(self.private_key, self.pubkey_num_lookup[pubkey])
|
|
84
85
|
return AugSchemeMPL.sign(privatekey, value)
|
|
85
86
|
|
|
86
|
-
def make_solution(self, condition_dic:
|
|
87
|
+
def make_solution(self, condition_dic: dict[ConditionOpcode, list[ConditionWithArgs]]) -> Program:
|
|
87
88
|
ret = []
|
|
88
89
|
|
|
89
90
|
for con_list in condition_dic.values():
|
|
90
91
|
for cvp in con_list:
|
|
91
92
|
if cvp.opcode == ConditionOpcode.CREATE_COIN and len(cvp.vars) > 2:
|
|
92
|
-
formatted:
|
|
93
|
+
formatted: list[Any] = []
|
|
93
94
|
formatted.extend(cvp.vars)
|
|
94
95
|
formatted[2] = cvp.vars[2:]
|
|
95
|
-
ret.append([cvp.opcode.value
|
|
96
|
+
ret.append([cvp.opcode.value, *formatted])
|
|
96
97
|
else:
|
|
97
|
-
ret.append([cvp.opcode.value
|
|
98
|
+
ret.append([cvp.opcode.value, *cvp.vars])
|
|
98
99
|
return solution_for_conditions(Program.to(ret))
|
|
99
100
|
|
|
100
101
|
def generate_unsigned_transaction(
|
|
101
102
|
self,
|
|
102
103
|
amount: uint64,
|
|
103
104
|
new_puzzle_hash: bytes32,
|
|
104
|
-
coins:
|
|
105
|
-
condition_dic:
|
|
105
|
+
coins: list[Coin],
|
|
106
|
+
condition_dic: dict[ConditionOpcode, list[ConditionWithArgs]],
|
|
106
107
|
fee: int = 0,
|
|
107
108
|
secret_key: Optional[PrivateKey] = None,
|
|
108
|
-
additional_outputs: Optional[
|
|
109
|
+
additional_outputs: Optional[list[tuple[bytes32, int]]] = None,
|
|
109
110
|
memo: Optional[bytes32] = None,
|
|
110
|
-
) ->
|
|
111
|
+
) -> list[CoinSpend]:
|
|
111
112
|
spends = []
|
|
112
113
|
|
|
113
114
|
spend_value = sum(c.amount for c in coins)
|
|
@@ -134,7 +135,7 @@ class WalletTool:
|
|
|
134
135
|
change_output = ConditionWithArgs(ConditionOpcode.CREATE_COIN, [change_puzzle_hash, int_to_bytes(change)])
|
|
135
136
|
condition_dic[output.opcode].append(change_output)
|
|
136
137
|
|
|
137
|
-
secondary_coins_cond_dic:
|
|
138
|
+
secondary_coins_cond_dic: dict[ConditionOpcode, list[ConditionWithArgs]] = dict()
|
|
138
139
|
secondary_coins_cond_dic[ConditionOpcode.ASSERT_COIN_ANNOUNCEMENT] = []
|
|
139
140
|
for n, coin in enumerate(coins):
|
|
140
141
|
puzzle_hash = coin.puzzle_hash
|
|
@@ -175,7 +176,7 @@ class WalletTool:
|
|
|
175
176
|
)
|
|
176
177
|
return spends
|
|
177
178
|
|
|
178
|
-
def sign_transaction(self, coin_spends:
|
|
179
|
+
def sign_transaction(self, coin_spends: list[CoinSpend]) -> SpendBundle:
|
|
179
180
|
signatures = []
|
|
180
181
|
data = agg_sig_additional_data(self.constants.AGG_SIG_ME_ADDITIONAL_DATA)
|
|
181
182
|
agg_sig_opcodes = [
|
|
@@ -214,9 +215,9 @@ class WalletTool:
|
|
|
214
215
|
amount: uint64,
|
|
215
216
|
new_puzzle_hash: bytes32,
|
|
216
217
|
coin: Coin,
|
|
217
|
-
condition_dic:
|
|
218
|
+
condition_dic: Optional[dict[ConditionOpcode, list[ConditionWithArgs]]] = None,
|
|
218
219
|
fee: int = 0,
|
|
219
|
-
additional_outputs: Optional[
|
|
220
|
+
additional_outputs: Optional[list[tuple[bytes32, int]]] = None,
|
|
220
221
|
memo: Optional[bytes32] = None,
|
|
221
222
|
) -> SpendBundle:
|
|
222
223
|
if condition_dic is None:
|
|
@@ -231,10 +232,10 @@ class WalletTool:
|
|
|
231
232
|
self,
|
|
232
233
|
amount: uint64,
|
|
233
234
|
new_puzzle_hash: bytes32,
|
|
234
|
-
coins:
|
|
235
|
-
condition_dic:
|
|
235
|
+
coins: list[Coin],
|
|
236
|
+
condition_dic: Optional[dict[ConditionOpcode, list[ConditionWithArgs]]] = None,
|
|
236
237
|
fee: int = 0,
|
|
237
|
-
additional_outputs: Optional[
|
|
238
|
+
additional_outputs: Optional[list[tuple[bytes32, int]]] = None,
|
|
238
239
|
) -> SpendBundle:
|
|
239
240
|
if condition_dic is None:
|
|
240
241
|
condition_dic = {}
|
chia/ssl/create_ssl.py
CHANGED
|
@@ -3,7 +3,7 @@ from __future__ import annotations
|
|
|
3
3
|
import datetime
|
|
4
4
|
import os
|
|
5
5
|
from pathlib import Path
|
|
6
|
-
from typing import Any,
|
|
6
|
+
from typing import Any, Optional
|
|
7
7
|
|
|
8
8
|
import importlib_resources
|
|
9
9
|
from cryptography import x509
|
|
@@ -15,7 +15,7 @@ from cryptography.x509.oid import NameOID
|
|
|
15
15
|
|
|
16
16
|
from chia.util.ssl_check import DEFAULT_PERMISSIONS_CERT_FILE, DEFAULT_PERMISSIONS_KEY_FILE
|
|
17
17
|
|
|
18
|
-
_all_private_node_names:
|
|
18
|
+
_all_private_node_names: list[str] = [
|
|
19
19
|
"full_node",
|
|
20
20
|
"wallet",
|
|
21
21
|
"farmer",
|
|
@@ -25,10 +25,10 @@ _all_private_node_names: List[str] = [
|
|
|
25
25
|
"data_layer",
|
|
26
26
|
"daemon",
|
|
27
27
|
]
|
|
28
|
-
_all_public_node_names:
|
|
28
|
+
_all_public_node_names: list[str] = ["full_node", "wallet", "farmer", "introducer", "timelord", "data_layer"]
|
|
29
29
|
|
|
30
30
|
|
|
31
|
-
def get_chia_ca_crt_key() ->
|
|
31
|
+
def get_chia_ca_crt_key() -> tuple[Any, Any]:
|
|
32
32
|
here = importlib_resources.files(__name__.rpartition(".")[0])
|
|
33
33
|
crt = here.joinpath("chia_ca.crt").read_bytes()
|
|
34
34
|
key = here.joinpath("chia_ca.key").read_bytes()
|
|
@@ -57,7 +57,7 @@ def write_ssl_cert_and_key(cert_path: Path, cert_data: bytes, key_path: Path, ke
|
|
|
57
57
|
f.write(data) # lgtm [py/clear-text-storage-sensitive-data]
|
|
58
58
|
|
|
59
59
|
|
|
60
|
-
def ensure_ssl_dirs(dirs:
|
|
60
|
+
def ensure_ssl_dirs(dirs: list[Path]):
|
|
61
61
|
"""Create SSL dirs with a default 755 mode if necessary"""
|
|
62
62
|
for dir in dirs:
|
|
63
63
|
if not dir.exists():
|
|
@@ -137,10 +137,10 @@ def make_ca_cert(cert_path: Path, key_path: Path):
|
|
|
137
137
|
def create_all_ssl(
|
|
138
138
|
root_path: Path,
|
|
139
139
|
*,
|
|
140
|
-
private_ca_crt_and_key: Optional[
|
|
141
|
-
node_certs_and_keys: Optional[
|
|
142
|
-
private_node_names:
|
|
143
|
-
public_node_names:
|
|
140
|
+
private_ca_crt_and_key: Optional[tuple[bytes, bytes]] = None,
|
|
141
|
+
node_certs_and_keys: Optional[dict[str, dict]] = None,
|
|
142
|
+
private_node_names: list[str] = _all_private_node_names,
|
|
143
|
+
public_node_names: list[str] = _all_public_node_names,
|
|
144
144
|
overwrite: bool = True,
|
|
145
145
|
):
|
|
146
146
|
# remove old key and crt
|
|
@@ -219,9 +219,9 @@ def generate_ssl_for_nodes(
|
|
|
219
219
|
ca_key: bytes,
|
|
220
220
|
*,
|
|
221
221
|
prefix: str,
|
|
222
|
-
nodes:
|
|
222
|
+
nodes: list[str],
|
|
223
223
|
overwrite: bool = True,
|
|
224
|
-
node_certs_and_keys: Optional[
|
|
224
|
+
node_certs_and_keys: Optional[dict[str, dict]] = None,
|
|
225
225
|
):
|
|
226
226
|
for node_name in nodes:
|
|
227
227
|
node_dir = ssl_dir / node_name
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
-
from typing import Optional,
|
|
3
|
+
from typing import Optional, Union
|
|
4
4
|
|
|
5
5
|
from chia.consensus.constants import ConsensusConstants
|
|
6
6
|
from chia.consensus.pot_iterations import calculate_ip_iters, calculate_iterations_quality, calculate_sp_iters
|
|
@@ -16,7 +16,7 @@ def iters_from_block(
|
|
|
16
16
|
sub_slot_iters: uint64,
|
|
17
17
|
difficulty: uint64,
|
|
18
18
|
height: uint32,
|
|
19
|
-
) ->
|
|
19
|
+
) -> tuple[uint64, uint64]:
|
|
20
20
|
if reward_chain_block.challenge_chain_sp_vdf is None:
|
|
21
21
|
assert reward_chain_block.signage_point_index == 0
|
|
22
22
|
cc_sp: bytes32 = reward_chain_block.pos_ss_cc_challenge_hash
|