chia-blockchain 2.5.1rc1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- chia/__init__.py +10 -0
- chia/__main__.py +5 -0
- chia/_tests/README.md +53 -0
- chia/_tests/__init__.py +0 -0
- chia/_tests/blockchain/__init__.py +0 -0
- chia/_tests/blockchain/blockchain_test_utils.py +195 -0
- chia/_tests/blockchain/config.py +4 -0
- chia/_tests/blockchain/test_augmented_chain.py +145 -0
- chia/_tests/blockchain/test_blockchain.py +4202 -0
- chia/_tests/blockchain/test_blockchain_transactions.py +1031 -0
- chia/_tests/blockchain/test_build_chains.py +59 -0
- chia/_tests/blockchain/test_get_block_generator.py +72 -0
- chia/_tests/blockchain/test_lookup_fork_chain.py +194 -0
- chia/_tests/build-init-files.py +92 -0
- chia/_tests/build-job-matrix.py +204 -0
- chia/_tests/check_pytest_monitor_output.py +34 -0
- chia/_tests/check_sql_statements.py +72 -0
- chia/_tests/chia-start-sim +42 -0
- chia/_tests/clvm/__init__.py +0 -0
- chia/_tests/clvm/benchmark_costs.py +23 -0
- chia/_tests/clvm/coin_store.py +149 -0
- chia/_tests/clvm/test_chialisp_deserialization.py +101 -0
- chia/_tests/clvm/test_clvm_step.py +37 -0
- chia/_tests/clvm/test_condition_codes.py +13 -0
- chia/_tests/clvm/test_curry_and_treehash.py +55 -0
- chia/_tests/clvm/test_message_conditions.py +184 -0
- chia/_tests/clvm/test_program.py +150 -0
- chia/_tests/clvm/test_puzzle_compression.py +143 -0
- chia/_tests/clvm/test_puzzle_drivers.py +45 -0
- chia/_tests/clvm/test_puzzles.py +242 -0
- chia/_tests/clvm/test_singletons.py +540 -0
- chia/_tests/clvm/test_spend_sim.py +181 -0
- chia/_tests/cmds/__init__.py +0 -0
- chia/_tests/cmds/cmd_test_utils.py +469 -0
- chia/_tests/cmds/config.py +3 -0
- chia/_tests/cmds/conftest.py +23 -0
- chia/_tests/cmds/test_click_types.py +200 -0
- chia/_tests/cmds/test_cmd_framework.py +620 -0
- chia/_tests/cmds/test_cmds_util.py +97 -0
- chia/_tests/cmds/test_daemon.py +92 -0
- chia/_tests/cmds/test_dev_gh.py +131 -0
- chia/_tests/cmds/test_farm_cmd.py +66 -0
- chia/_tests/cmds/test_show.py +116 -0
- chia/_tests/cmds/test_sim.py +207 -0
- chia/_tests/cmds/test_timelock_args.py +75 -0
- chia/_tests/cmds/test_tx_config_args.py +154 -0
- chia/_tests/cmds/testing_classes.py +59 -0
- chia/_tests/cmds/wallet/__init__.py +0 -0
- chia/_tests/cmds/wallet/test_consts.py +47 -0
- chia/_tests/cmds/wallet/test_dao.py +565 -0
- chia/_tests/cmds/wallet/test_did.py +403 -0
- chia/_tests/cmds/wallet/test_nft.py +471 -0
- chia/_tests/cmds/wallet/test_notifications.py +124 -0
- chia/_tests/cmds/wallet/test_offer.toffer +1 -0
- chia/_tests/cmds/wallet/test_tx_decorators.py +27 -0
- chia/_tests/cmds/wallet/test_vcs.py +400 -0
- chia/_tests/cmds/wallet/test_wallet.py +1125 -0
- chia/_tests/cmds/wallet/test_wallet_check.py +109 -0
- chia/_tests/conftest.py +1419 -0
- chia/_tests/connection_utils.py +125 -0
- chia/_tests/core/__init__.py +0 -0
- chia/_tests/core/cmds/__init__.py +0 -0
- chia/_tests/core/cmds/test_beta.py +382 -0
- chia/_tests/core/cmds/test_keys.py +1734 -0
- chia/_tests/core/cmds/test_wallet.py +126 -0
- chia/_tests/core/config.py +3 -0
- chia/_tests/core/consensus/__init__.py +0 -0
- chia/_tests/core/consensus/test_block_creation.py +54 -0
- chia/_tests/core/consensus/test_pot_iterations.py +117 -0
- chia/_tests/core/custom_types/__init__.py +0 -0
- chia/_tests/core/custom_types/test_coin.py +107 -0
- chia/_tests/core/custom_types/test_proof_of_space.py +144 -0
- chia/_tests/core/custom_types/test_spend_bundle.py +70 -0
- chia/_tests/core/daemon/__init__.py +0 -0
- chia/_tests/core/daemon/config.py +4 -0
- chia/_tests/core/daemon/test_daemon.py +2128 -0
- chia/_tests/core/daemon/test_daemon_register.py +109 -0
- chia/_tests/core/daemon/test_keychain_proxy.py +101 -0
- chia/_tests/core/data_layer/__init__.py +0 -0
- chia/_tests/core/data_layer/config.py +5 -0
- chia/_tests/core/data_layer/conftest.py +106 -0
- chia/_tests/core/data_layer/test_data_cli.py +56 -0
- chia/_tests/core/data_layer/test_data_layer.py +83 -0
- chia/_tests/core/data_layer/test_data_layer_util.py +218 -0
- chia/_tests/core/data_layer/test_data_rpc.py +3847 -0
- chia/_tests/core/data_layer/test_data_store.py +2424 -0
- chia/_tests/core/data_layer/test_data_store_schema.py +381 -0
- chia/_tests/core/data_layer/test_plugin.py +91 -0
- chia/_tests/core/data_layer/util.py +233 -0
- chia/_tests/core/farmer/__init__.py +0 -0
- chia/_tests/core/farmer/config.py +3 -0
- chia/_tests/core/farmer/test_farmer_api.py +103 -0
- chia/_tests/core/full_node/__init__.py +0 -0
- chia/_tests/core/full_node/config.py +4 -0
- chia/_tests/core/full_node/dos/__init__.py +0 -0
- chia/_tests/core/full_node/dos/config.py +3 -0
- chia/_tests/core/full_node/full_sync/__init__.py +0 -0
- chia/_tests/core/full_node/full_sync/config.py +4 -0
- chia/_tests/core/full_node/full_sync/test_full_sync.py +443 -0
- chia/_tests/core/full_node/ram_db.py +27 -0
- chia/_tests/core/full_node/stores/__init__.py +0 -0
- chia/_tests/core/full_node/stores/config.py +4 -0
- chia/_tests/core/full_node/stores/test_block_store.py +590 -0
- chia/_tests/core/full_node/stores/test_coin_store.py +897 -0
- chia/_tests/core/full_node/stores/test_full_node_store.py +1219 -0
- chia/_tests/core/full_node/stores/test_hint_store.py +229 -0
- chia/_tests/core/full_node/stores/test_sync_store.py +135 -0
- chia/_tests/core/full_node/test_address_manager.py +588 -0
- chia/_tests/core/full_node/test_block_height_map.py +556 -0
- chia/_tests/core/full_node/test_conditions.py +556 -0
- chia/_tests/core/full_node/test_full_node.py +2700 -0
- chia/_tests/core/full_node/test_generator_tools.py +82 -0
- chia/_tests/core/full_node/test_hint_management.py +104 -0
- chia/_tests/core/full_node/test_node_load.py +34 -0
- chia/_tests/core/full_node/test_performance.py +179 -0
- chia/_tests/core/full_node/test_subscriptions.py +492 -0
- chia/_tests/core/full_node/test_transactions.py +203 -0
- chia/_tests/core/full_node/test_tx_processing_queue.py +155 -0
- chia/_tests/core/large_block.py +2388 -0
- chia/_tests/core/make_block_generator.py +70 -0
- chia/_tests/core/mempool/__init__.py +0 -0
- chia/_tests/core/mempool/config.py +4 -0
- chia/_tests/core/mempool/test_mempool.py +3255 -0
- chia/_tests/core/mempool/test_mempool_fee_estimator.py +104 -0
- chia/_tests/core/mempool/test_mempool_fee_protocol.py +55 -0
- chia/_tests/core/mempool/test_mempool_item_queries.py +190 -0
- chia/_tests/core/mempool/test_mempool_manager.py +2084 -0
- chia/_tests/core/mempool/test_mempool_performance.py +64 -0
- chia/_tests/core/mempool/test_singleton_fast_forward.py +567 -0
- chia/_tests/core/node_height.py +28 -0
- chia/_tests/core/server/__init__.py +0 -0
- chia/_tests/core/server/config.py +3 -0
- chia/_tests/core/server/flood.py +84 -0
- chia/_tests/core/server/serve.py +135 -0
- chia/_tests/core/server/test_api_protocol.py +21 -0
- chia/_tests/core/server/test_capabilities.py +66 -0
- chia/_tests/core/server/test_dos.py +319 -0
- chia/_tests/core/server/test_event_loop.py +109 -0
- chia/_tests/core/server/test_loop.py +294 -0
- chia/_tests/core/server/test_node_discovery.py +73 -0
- chia/_tests/core/server/test_rate_limits.py +482 -0
- chia/_tests/core/server/test_server.py +226 -0
- chia/_tests/core/server/test_upnp.py +8 -0
- chia/_tests/core/services/__init__.py +0 -0
- chia/_tests/core/services/config.py +3 -0
- chia/_tests/core/services/test_services.py +188 -0
- chia/_tests/core/ssl/__init__.py +0 -0
- chia/_tests/core/ssl/config.py +3 -0
- chia/_tests/core/ssl/test_ssl.py +202 -0
- chia/_tests/core/test_coins.py +33 -0
- chia/_tests/core/test_cost_calculation.py +313 -0
- chia/_tests/core/test_crawler.py +175 -0
- chia/_tests/core/test_crawler_rpc.py +53 -0
- chia/_tests/core/test_daemon_rpc.py +24 -0
- chia/_tests/core/test_db_conversion.py +130 -0
- chia/_tests/core/test_db_validation.py +162 -0
- chia/_tests/core/test_farmer_harvester_rpc.py +505 -0
- chia/_tests/core/test_filter.py +35 -0
- chia/_tests/core/test_full_node_rpc.py +768 -0
- chia/_tests/core/test_merkle_set.py +343 -0
- chia/_tests/core/test_program.py +47 -0
- chia/_tests/core/test_rpc_util.py +86 -0
- chia/_tests/core/test_seeder.py +420 -0
- chia/_tests/core/test_setproctitle.py +13 -0
- chia/_tests/core/util/__init__.py +0 -0
- chia/_tests/core/util/config.py +4 -0
- chia/_tests/core/util/test_block_cache.py +44 -0
- chia/_tests/core/util/test_cached_bls.py +57 -0
- chia/_tests/core/util/test_config.py +337 -0
- chia/_tests/core/util/test_file_keyring_synchronization.py +105 -0
- chia/_tests/core/util/test_files.py +391 -0
- chia/_tests/core/util/test_jsonify.py +146 -0
- chia/_tests/core/util/test_keychain.py +522 -0
- chia/_tests/core/util/test_keyring_wrapper.py +491 -0
- chia/_tests/core/util/test_lockfile.py +380 -0
- chia/_tests/core/util/test_log_exceptions.py +187 -0
- chia/_tests/core/util/test_lru_cache.py +56 -0
- chia/_tests/core/util/test_significant_bits.py +40 -0
- chia/_tests/core/util/test_streamable.py +883 -0
- chia/_tests/db/__init__.py +0 -0
- chia/_tests/db/test_db_wrapper.py +566 -0
- chia/_tests/environments/__init__.py +0 -0
- chia/_tests/environments/common.py +35 -0
- chia/_tests/environments/full_node.py +47 -0
- chia/_tests/environments/wallet.py +429 -0
- chia/_tests/ether.py +19 -0
- chia/_tests/farmer_harvester/__init__.py +0 -0
- chia/_tests/farmer_harvester/config.py +3 -0
- chia/_tests/farmer_harvester/test_farmer.py +1264 -0
- chia/_tests/farmer_harvester/test_farmer_harvester.py +292 -0
- chia/_tests/farmer_harvester/test_filter_prefix_bits.py +131 -0
- chia/_tests/farmer_harvester/test_third_party_harvesters.py +528 -0
- chia/_tests/farmer_harvester/test_third_party_harvesters_data.json +29 -0
- chia/_tests/fee_estimation/__init__.py +0 -0
- chia/_tests/fee_estimation/config.py +3 -0
- chia/_tests/fee_estimation/test_fee_estimation_integration.py +262 -0
- chia/_tests/fee_estimation/test_fee_estimation_rpc.py +287 -0
- chia/_tests/fee_estimation/test_fee_estimation_unit_tests.py +144 -0
- chia/_tests/fee_estimation/test_mempoolitem_height_added.py +146 -0
- chia/_tests/generator/__init__.py +0 -0
- chia/_tests/generator/puzzles/__init__.py +0 -0
- chia/_tests/generator/puzzles/test_generator_deserialize.clsp +3 -0
- chia/_tests/generator/puzzles/test_generator_deserialize.clsp.hex +1 -0
- chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp +19 -0
- chia/_tests/generator/puzzles/test_multiple_generator_input_arguments.clsp.hex +1 -0
- chia/_tests/generator/test_compression.py +201 -0
- chia/_tests/generator/test_generator_types.py +44 -0
- chia/_tests/generator/test_rom.py +180 -0
- chia/_tests/plot_sync/__init__.py +0 -0
- chia/_tests/plot_sync/config.py +3 -0
- chia/_tests/plot_sync/test_delta.py +101 -0
- chia/_tests/plot_sync/test_plot_sync.py +618 -0
- chia/_tests/plot_sync/test_receiver.py +451 -0
- chia/_tests/plot_sync/test_sender.py +116 -0
- chia/_tests/plot_sync/test_sync_simulated.py +451 -0
- chia/_tests/plot_sync/util.py +68 -0
- chia/_tests/plotting/__init__.py +0 -0
- chia/_tests/plotting/config.py +3 -0
- chia/_tests/plotting/test_plot_manager.py +781 -0
- chia/_tests/plotting/util.py +12 -0
- chia/_tests/pools/__init__.py +0 -0
- chia/_tests/pools/config.py +5 -0
- chia/_tests/pools/test_pool_cli_parsing.py +128 -0
- chia/_tests/pools/test_pool_cmdline.py +1001 -0
- chia/_tests/pools/test_pool_config.py +42 -0
- chia/_tests/pools/test_pool_puzzles_lifecycle.py +397 -0
- chia/_tests/pools/test_pool_rpc.py +1123 -0
- chia/_tests/pools/test_pool_wallet.py +205 -0
- chia/_tests/pools/test_wallet_pool_store.py +161 -0
- chia/_tests/process_junit.py +348 -0
- chia/_tests/rpc/__init__.py +0 -0
- chia/_tests/rpc/test_rpc_client.py +138 -0
- chia/_tests/rpc/test_rpc_server.py +183 -0
- chia/_tests/simulation/__init__.py +0 -0
- chia/_tests/simulation/config.py +6 -0
- chia/_tests/simulation/test_simulation.py +501 -0
- chia/_tests/simulation/test_simulator.py +232 -0
- chia/_tests/simulation/test_start_simulator.py +107 -0
- chia/_tests/testconfig.py +13 -0
- chia/_tests/timelord/__init__.py +0 -0
- chia/_tests/timelord/config.py +3 -0
- chia/_tests/timelord/test_new_peak.py +437 -0
- chia/_tests/timelord/test_timelord.py +11 -0
- chia/_tests/tools/1315537.json +170 -0
- chia/_tests/tools/1315544.json +160 -0
- chia/_tests/tools/1315630.json +150 -0
- chia/_tests/tools/300000.json +105 -0
- chia/_tests/tools/442734.json +140 -0
- chia/_tests/tools/466212.json +130 -0
- chia/_tests/tools/__init__.py +0 -0
- chia/_tests/tools/config.py +5 -0
- chia/_tests/tools/test-blockchain-db.sqlite +0 -0
- chia/_tests/tools/test_full_sync.py +30 -0
- chia/_tests/tools/test_legacy_keyring.py +82 -0
- chia/_tests/tools/test_run_block.py +128 -0
- chia/_tests/tools/test_virtual_project.py +591 -0
- chia/_tests/util/__init__.py +0 -0
- chia/_tests/util/benchmark_cost.py +170 -0
- chia/_tests/util/benchmarks.py +153 -0
- chia/_tests/util/bip39_test_vectors.json +148 -0
- chia/_tests/util/blockchain.py +134 -0
- chia/_tests/util/blockchain_mock.py +132 -0
- chia/_tests/util/build_network_protocol_files.py +302 -0
- chia/_tests/util/clvm_generator.bin +0 -0
- chia/_tests/util/config.py +3 -0
- chia/_tests/util/constants.py +20 -0
- chia/_tests/util/db_connection.py +37 -0
- chia/_tests/util/full_sync.py +253 -0
- chia/_tests/util/gen_ssl_certs.py +114 -0
- chia/_tests/util/generator_tools_testing.py +45 -0
- chia/_tests/util/get_name_puzzle_conditions.py +52 -0
- chia/_tests/util/key_tool.py +36 -0
- chia/_tests/util/misc.py +675 -0
- chia/_tests/util/network_protocol_data.py +1072 -0
- chia/_tests/util/protocol_messages_bytes-v1.0 +0 -0
- chia/_tests/util/protocol_messages_json.py +2701 -0
- chia/_tests/util/rpc.py +26 -0
- chia/_tests/util/run_block.py +163 -0
- chia/_tests/util/setup_nodes.py +481 -0
- chia/_tests/util/spend_sim.py +492 -0
- chia/_tests/util/split_managers.py +102 -0
- chia/_tests/util/temp_file.py +14 -0
- chia/_tests/util/test_action_scope.py +144 -0
- chia/_tests/util/test_async_pool.py +366 -0
- chia/_tests/util/test_build_job_matrix.py +42 -0
- chia/_tests/util/test_build_network_protocol_files.py +7 -0
- chia/_tests/util/test_chia_version.py +50 -0
- chia/_tests/util/test_collection.py +11 -0
- chia/_tests/util/test_condition_tools.py +229 -0
- chia/_tests/util/test_config.py +426 -0
- chia/_tests/util/test_dump_keyring.py +60 -0
- chia/_tests/util/test_errors.py +10 -0
- chia/_tests/util/test_full_block_utils.py +279 -0
- chia/_tests/util/test_installed.py +20 -0
- chia/_tests/util/test_limited_semaphore.py +53 -0
- chia/_tests/util/test_logging_filter.py +42 -0
- chia/_tests/util/test_misc.py +445 -0
- chia/_tests/util/test_network.py +73 -0
- chia/_tests/util/test_network_protocol_files.py +578 -0
- chia/_tests/util/test_network_protocol_json.py +267 -0
- chia/_tests/util/test_network_protocol_test.py +256 -0
- chia/_tests/util/test_paginator.py +71 -0
- chia/_tests/util/test_pprint.py +17 -0
- chia/_tests/util/test_priority_mutex.py +488 -0
- chia/_tests/util/test_recursive_replace.py +116 -0
- chia/_tests/util/test_replace_str_to_bytes.py +137 -0
- chia/_tests/util/test_service_groups.py +15 -0
- chia/_tests/util/test_ssl_check.py +31 -0
- chia/_tests/util/test_testnet_overrides.py +19 -0
- chia/_tests/util/test_tests_misc.py +38 -0
- chia/_tests/util/test_timing.py +37 -0
- chia/_tests/util/test_trusted_peer.py +51 -0
- chia/_tests/util/time_out_assert.py +191 -0
- chia/_tests/wallet/__init__.py +0 -0
- chia/_tests/wallet/cat_wallet/__init__.py +0 -0
- chia/_tests/wallet/cat_wallet/config.py +4 -0
- chia/_tests/wallet/cat_wallet/test_cat_lifecycle.py +468 -0
- chia/_tests/wallet/cat_wallet/test_cat_outer_puzzle.py +69 -0
- chia/_tests/wallet/cat_wallet/test_cat_wallet.py +1826 -0
- chia/_tests/wallet/cat_wallet/test_offer_lifecycle.py +291 -0
- chia/_tests/wallet/cat_wallet/test_trades.py +2600 -0
- chia/_tests/wallet/clawback/__init__.py +0 -0
- chia/_tests/wallet/clawback/config.py +3 -0
- chia/_tests/wallet/clawback/test_clawback_decorator.py +78 -0
- chia/_tests/wallet/clawback/test_clawback_lifecycle.py +292 -0
- chia/_tests/wallet/clawback/test_clawback_metadata.py +50 -0
- chia/_tests/wallet/config.py +4 -0
- chia/_tests/wallet/conftest.py +278 -0
- chia/_tests/wallet/dao_wallet/__init__.py +0 -0
- chia/_tests/wallet/dao_wallet/config.py +3 -0
- chia/_tests/wallet/dao_wallet/test_dao_clvm.py +1330 -0
- chia/_tests/wallet/dao_wallet/test_dao_wallets.py +3488 -0
- chia/_tests/wallet/db_wallet/__init__.py +0 -0
- chia/_tests/wallet/db_wallet/config.py +3 -0
- chia/_tests/wallet/db_wallet/test_db_graftroot.py +141 -0
- chia/_tests/wallet/db_wallet/test_dl_offers.py +491 -0
- chia/_tests/wallet/db_wallet/test_dl_wallet.py +823 -0
- chia/_tests/wallet/did_wallet/__init__.py +0 -0
- chia/_tests/wallet/did_wallet/config.py +4 -0
- chia/_tests/wallet/did_wallet/test_did.py +2284 -0
- chia/_tests/wallet/nft_wallet/__init__.py +0 -0
- chia/_tests/wallet/nft_wallet/config.py +4 -0
- chia/_tests/wallet/nft_wallet/test_nft_1_offers.py +1493 -0
- chia/_tests/wallet/nft_wallet/test_nft_bulk_mint.py +1024 -0
- chia/_tests/wallet/nft_wallet/test_nft_lifecycle.py +375 -0
- chia/_tests/wallet/nft_wallet/test_nft_offers.py +1209 -0
- chia/_tests/wallet/nft_wallet/test_nft_puzzles.py +172 -0
- chia/_tests/wallet/nft_wallet/test_nft_wallet.py +2584 -0
- chia/_tests/wallet/nft_wallet/test_ownership_outer_puzzle.py +70 -0
- chia/_tests/wallet/rpc/__init__.py +0 -0
- chia/_tests/wallet/rpc/config.py +4 -0
- chia/_tests/wallet/rpc/test_dl_wallet_rpc.py +285 -0
- chia/_tests/wallet/rpc/test_wallet_rpc.py +3153 -0
- chia/_tests/wallet/simple_sync/__init__.py +0 -0
- chia/_tests/wallet/simple_sync/config.py +3 -0
- chia/_tests/wallet/simple_sync/test_simple_sync_protocol.py +718 -0
- chia/_tests/wallet/sync/__init__.py +0 -0
- chia/_tests/wallet/sync/config.py +4 -0
- chia/_tests/wallet/sync/test_wallet_sync.py +1692 -0
- chia/_tests/wallet/test_address_type.py +189 -0
- chia/_tests/wallet/test_bech32m.py +45 -0
- chia/_tests/wallet/test_clvm_streamable.py +244 -0
- chia/_tests/wallet/test_coin_management.py +354 -0
- chia/_tests/wallet/test_coin_selection.py +588 -0
- chia/_tests/wallet/test_conditions.py +400 -0
- chia/_tests/wallet/test_debug_spend_bundle.py +218 -0
- chia/_tests/wallet/test_new_wallet_protocol.py +1174 -0
- chia/_tests/wallet/test_nft_store.py +192 -0
- chia/_tests/wallet/test_notifications.py +196 -0
- chia/_tests/wallet/test_offer_parsing_performance.py +48 -0
- chia/_tests/wallet/test_puzzle_store.py +132 -0
- chia/_tests/wallet/test_sign_coin_spends.py +159 -0
- chia/_tests/wallet/test_signer_protocol.py +947 -0
- chia/_tests/wallet/test_singleton.py +122 -0
- chia/_tests/wallet/test_singleton_lifecycle_fast.py +772 -0
- chia/_tests/wallet/test_singleton_store.py +152 -0
- chia/_tests/wallet/test_taproot.py +19 -0
- chia/_tests/wallet/test_transaction_store.py +945 -0
- chia/_tests/wallet/test_util.py +185 -0
- chia/_tests/wallet/test_wallet.py +2139 -0
- chia/_tests/wallet/test_wallet_action_scope.py +85 -0
- chia/_tests/wallet/test_wallet_blockchain.py +111 -0
- chia/_tests/wallet/test_wallet_coin_store.py +1002 -0
- chia/_tests/wallet/test_wallet_interested_store.py +43 -0
- chia/_tests/wallet/test_wallet_key_val_store.py +40 -0
- chia/_tests/wallet/test_wallet_node.py +780 -0
- chia/_tests/wallet/test_wallet_retry.py +95 -0
- chia/_tests/wallet/test_wallet_state_manager.py +259 -0
- chia/_tests/wallet/test_wallet_test_framework.py +275 -0
- chia/_tests/wallet/test_wallet_trade_store.py +218 -0
- chia/_tests/wallet/test_wallet_user_store.py +34 -0
- chia/_tests/wallet/test_wallet_utils.py +156 -0
- chia/_tests/wallet/vc_wallet/__init__.py +0 -0
- chia/_tests/wallet/vc_wallet/config.py +3 -0
- chia/_tests/wallet/vc_wallet/test_cr_outer_puzzle.py +70 -0
- chia/_tests/wallet/vc_wallet/test_vc_lifecycle.py +883 -0
- chia/_tests/wallet/vc_wallet/test_vc_wallet.py +830 -0
- chia/_tests/wallet/wallet_block_tools.py +327 -0
- chia/_tests/weight_proof/__init__.py +0 -0
- chia/_tests/weight_proof/config.py +3 -0
- chia/_tests/weight_proof/test_weight_proof.py +528 -0
- chia/apis.py +19 -0
- chia/clvm/__init__.py +0 -0
- chia/cmds/__init__.py +0 -0
- chia/cmds/beta.py +184 -0
- chia/cmds/beta_funcs.py +137 -0
- chia/cmds/check_wallet_db.py +420 -0
- chia/cmds/chia.py +151 -0
- chia/cmds/cmd_classes.py +323 -0
- chia/cmds/cmd_helpers.py +242 -0
- chia/cmds/cmds_util.py +488 -0
- chia/cmds/coin_funcs.py +275 -0
- chia/cmds/coins.py +182 -0
- chia/cmds/completion.py +49 -0
- chia/cmds/configure.py +332 -0
- chia/cmds/dao.py +1064 -0
- chia/cmds/dao_funcs.py +598 -0
- chia/cmds/data.py +708 -0
- chia/cmds/data_funcs.py +385 -0
- chia/cmds/db.py +87 -0
- chia/cmds/db_backup_func.py +77 -0
- chia/cmds/db_upgrade_func.py +452 -0
- chia/cmds/db_validate_func.py +184 -0
- chia/cmds/dev.py +18 -0
- chia/cmds/farm.py +100 -0
- chia/cmds/farm_funcs.py +200 -0
- chia/cmds/gh.py +275 -0
- chia/cmds/init.py +63 -0
- chia/cmds/init_funcs.py +367 -0
- chia/cmds/installers.py +131 -0
- chia/cmds/keys.py +527 -0
- chia/cmds/keys_funcs.py +863 -0
- chia/cmds/netspace.py +50 -0
- chia/cmds/netspace_funcs.py +54 -0
- chia/cmds/options.py +32 -0
- chia/cmds/param_types.py +238 -0
- chia/cmds/passphrase.py +131 -0
- chia/cmds/passphrase_funcs.py +292 -0
- chia/cmds/peer.py +51 -0
- chia/cmds/peer_funcs.py +129 -0
- chia/cmds/plotnft.py +260 -0
- chia/cmds/plotnft_funcs.py +405 -0
- chia/cmds/plots.py +230 -0
- chia/cmds/plotters.py +18 -0
- chia/cmds/rpc.py +208 -0
- chia/cmds/show.py +72 -0
- chia/cmds/show_funcs.py +215 -0
- chia/cmds/signer.py +296 -0
- chia/cmds/sim.py +225 -0
- chia/cmds/sim_funcs.py +509 -0
- chia/cmds/start.py +24 -0
- chia/cmds/start_funcs.py +109 -0
- chia/cmds/stop.py +62 -0
- chia/cmds/units.py +9 -0
- chia/cmds/wallet.py +1901 -0
- chia/cmds/wallet_funcs.py +1874 -0
- chia/consensus/__init__.py +0 -0
- chia/consensus/block_body_validation.py +562 -0
- chia/consensus/block_creation.py +546 -0
- chia/consensus/block_header_validation.py +1059 -0
- chia/consensus/block_record.py +31 -0
- chia/consensus/block_rewards.py +53 -0
- chia/consensus/blockchain.py +1087 -0
- chia/consensus/blockchain_interface.py +56 -0
- chia/consensus/coinbase.py +30 -0
- chia/consensus/condition_costs.py +9 -0
- chia/consensus/constants.py +49 -0
- chia/consensus/cost_calculator.py +15 -0
- chia/consensus/default_constants.py +89 -0
- chia/consensus/deficit.py +55 -0
- chia/consensus/difficulty_adjustment.py +412 -0
- chia/consensus/find_fork_point.py +111 -0
- chia/consensus/full_block_to_block_record.py +167 -0
- chia/consensus/get_block_challenge.py +106 -0
- chia/consensus/get_block_generator.py +27 -0
- chia/consensus/make_sub_epoch_summary.py +210 -0
- chia/consensus/multiprocess_validation.py +268 -0
- chia/consensus/pos_quality.py +19 -0
- chia/consensus/pot_iterations.py +67 -0
- chia/consensus/puzzles/__init__.py +0 -0
- chia/consensus/puzzles/chialisp_deserialisation.clsp +69 -0
- chia/consensus/puzzles/chialisp_deserialisation.clsp.hex +1 -0
- chia/consensus/puzzles/rom_bootstrap_generator.clsp +37 -0
- chia/consensus/puzzles/rom_bootstrap_generator.clsp.hex +1 -0
- chia/consensus/vdf_info_computation.py +156 -0
- chia/daemon/__init__.py +0 -0
- chia/daemon/client.py +252 -0
- chia/daemon/keychain_proxy.py +502 -0
- chia/daemon/keychain_server.py +365 -0
- chia/daemon/server.py +1606 -0
- chia/daemon/windows_signal.py +56 -0
- chia/data_layer/__init__.py +0 -0
- chia/data_layer/data_layer.py +1291 -0
- chia/data_layer/data_layer_api.py +33 -0
- chia/data_layer/data_layer_errors.py +50 -0
- chia/data_layer/data_layer_server.py +170 -0
- chia/data_layer/data_layer_util.py +985 -0
- chia/data_layer/data_layer_wallet.py +1311 -0
- chia/data_layer/data_store.py +2267 -0
- chia/data_layer/dl_wallet_store.py +407 -0
- chia/data_layer/download_data.py +389 -0
- chia/data_layer/puzzles/__init__.py +0 -0
- chia/data_layer/puzzles/graftroot_dl_offers.clsp +100 -0
- chia/data_layer/puzzles/graftroot_dl_offers.clsp.hex +1 -0
- chia/data_layer/s3_plugin_config.yml +33 -0
- chia/data_layer/s3_plugin_service.py +468 -0
- chia/data_layer/util/__init__.py +0 -0
- chia/data_layer/util/benchmark.py +107 -0
- chia/data_layer/util/plugin.py +40 -0
- chia/farmer/__init__.py +0 -0
- chia/farmer/farmer.py +923 -0
- chia/farmer/farmer_api.py +820 -0
- chia/full_node/__init__.py +0 -0
- chia/full_node/bitcoin_fee_estimator.py +85 -0
- chia/full_node/block_height_map.py +271 -0
- chia/full_node/block_store.py +576 -0
- chia/full_node/bundle_tools.py +19 -0
- chia/full_node/coin_store.py +647 -0
- chia/full_node/fee_estimate.py +54 -0
- chia/full_node/fee_estimate_store.py +24 -0
- chia/full_node/fee_estimation.py +92 -0
- chia/full_node/fee_estimator.py +90 -0
- chia/full_node/fee_estimator_constants.py +38 -0
- chia/full_node/fee_estimator_interface.py +42 -0
- chia/full_node/fee_history.py +25 -0
- chia/full_node/fee_tracker.py +564 -0
- chia/full_node/full_node.py +3327 -0
- chia/full_node/full_node_api.py +2025 -0
- chia/full_node/full_node_store.py +1033 -0
- chia/full_node/hint_management.py +56 -0
- chia/full_node/hint_store.py +93 -0
- chia/full_node/mempool.py +589 -0
- chia/full_node/mempool_check_conditions.py +146 -0
- chia/full_node/mempool_manager.py +853 -0
- chia/full_node/pending_tx_cache.py +112 -0
- chia/full_node/puzzles/__init__.py +0 -0
- chia/full_node/puzzles/block_program_zero.clsp +14 -0
- chia/full_node/puzzles/block_program_zero.clsp.hex +1 -0
- chia/full_node/puzzles/decompress_coin_spend_entry.clsp +5 -0
- chia/full_node/puzzles/decompress_coin_spend_entry.clsp.hex +1 -0
- chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp +7 -0
- chia/full_node/puzzles/decompress_coin_spend_entry_with_prefix.clsp.hex +1 -0
- chia/full_node/puzzles/decompress_puzzle.clsp +6 -0
- chia/full_node/puzzles/decompress_puzzle.clsp.hex +1 -0
- chia/full_node/signage_point.py +16 -0
- chia/full_node/subscriptions.py +247 -0
- chia/full_node/sync_store.py +146 -0
- chia/full_node/tx_processing_queue.py +78 -0
- chia/full_node/util/__init__.py +0 -0
- chia/full_node/weight_proof.py +1720 -0
- chia/harvester/__init__.py +0 -0
- chia/harvester/harvester.py +272 -0
- chia/harvester/harvester_api.py +380 -0
- chia/introducer/__init__.py +0 -0
- chia/introducer/introducer.py +122 -0
- chia/introducer/introducer_api.py +70 -0
- chia/legacy/__init__.py +0 -0
- chia/legacy/keyring.py +155 -0
- chia/plot_sync/__init__.py +0 -0
- chia/plot_sync/delta.py +61 -0
- chia/plot_sync/exceptions.py +56 -0
- chia/plot_sync/receiver.py +386 -0
- chia/plot_sync/sender.py +340 -0
- chia/plot_sync/util.py +43 -0
- chia/plotters/__init__.py +0 -0
- chia/plotters/bladebit.py +388 -0
- chia/plotters/chiapos.py +63 -0
- chia/plotters/madmax.py +224 -0
- chia/plotters/plotters.py +577 -0
- chia/plotters/plotters_util.py +133 -0
- chia/plotting/__init__.py +0 -0
- chia/plotting/cache.py +213 -0
- chia/plotting/check_plots.py +283 -0
- chia/plotting/create_plots.py +278 -0
- chia/plotting/manager.py +436 -0
- chia/plotting/util.py +336 -0
- chia/pools/__init__.py +0 -0
- chia/pools/pool_config.py +110 -0
- chia/pools/pool_puzzles.py +459 -0
- chia/pools/pool_wallet.py +933 -0
- chia/pools/pool_wallet_info.py +118 -0
- chia/pools/puzzles/__init__.py +0 -0
- chia/pools/puzzles/pool_member_innerpuz.clsp +70 -0
- chia/pools/puzzles/pool_member_innerpuz.clsp.hex +1 -0
- chia/pools/puzzles/pool_waitingroom_innerpuz.clsp +69 -0
- chia/pools/puzzles/pool_waitingroom_innerpuz.clsp.hex +1 -0
- chia/protocols/__init__.py +0 -0
- chia/protocols/farmer_protocol.py +102 -0
- chia/protocols/full_node_protocol.py +219 -0
- chia/protocols/harvester_protocol.py +216 -0
- chia/protocols/introducer_protocol.py +25 -0
- chia/protocols/pool_protocol.py +177 -0
- chia/protocols/protocol_message_types.py +139 -0
- chia/protocols/protocol_state_machine.py +87 -0
- chia/protocols/protocol_timing.py +8 -0
- chia/protocols/shared_protocol.py +86 -0
- chia/protocols/timelord_protocol.py +93 -0
- chia/protocols/wallet_protocol.py +401 -0
- chia/py.typed +0 -0
- chia/rpc/__init__.py +0 -0
- chia/rpc/crawler_rpc_api.py +80 -0
- chia/rpc/data_layer_rpc_api.py +644 -0
- chia/rpc/data_layer_rpc_client.py +188 -0
- chia/rpc/data_layer_rpc_util.py +58 -0
- chia/rpc/farmer_rpc_api.py +365 -0
- chia/rpc/farmer_rpc_client.py +86 -0
- chia/rpc/full_node_rpc_api.py +959 -0
- chia/rpc/full_node_rpc_client.py +292 -0
- chia/rpc/harvester_rpc_api.py +141 -0
- chia/rpc/harvester_rpc_client.py +54 -0
- chia/rpc/rpc_client.py +164 -0
- chia/rpc/rpc_server.py +521 -0
- chia/rpc/timelord_rpc_api.py +32 -0
- chia/rpc/util.py +93 -0
- chia/rpc/wallet_request_types.py +904 -0
- chia/rpc/wallet_rpc_api.py +4943 -0
- chia/rpc/wallet_rpc_client.py +1814 -0
- chia/seeder/__init__.py +0 -0
- chia/seeder/crawl_store.py +425 -0
- chia/seeder/crawler.py +410 -0
- chia/seeder/crawler_api.py +135 -0
- chia/seeder/dns_server.py +593 -0
- chia/seeder/peer_record.py +146 -0
- chia/seeder/start_crawler.py +92 -0
- chia/server/__init__.py +0 -0
- chia/server/address_manager.py +658 -0
- chia/server/address_manager_store.py +237 -0
- chia/server/api_protocol.py +116 -0
- chia/server/capabilities.py +24 -0
- chia/server/chia_policy.py +346 -0
- chia/server/introducer_peers.py +76 -0
- chia/server/node_discovery.py +714 -0
- chia/server/outbound_message.py +33 -0
- chia/server/rate_limit_numbers.py +214 -0
- chia/server/rate_limits.py +153 -0
- chia/server/server.py +741 -0
- chia/server/signal_handlers.py +120 -0
- chia/server/ssl_context.py +32 -0
- chia/server/start_data_layer.py +151 -0
- chia/server/start_farmer.py +98 -0
- chia/server/start_full_node.py +112 -0
- chia/server/start_harvester.py +93 -0
- chia/server/start_introducer.py +81 -0
- chia/server/start_service.py +316 -0
- chia/server/start_timelord.py +89 -0
- chia/server/start_wallet.py +113 -0
- chia/server/upnp.py +118 -0
- chia/server/ws_connection.py +766 -0
- chia/simulator/__init__.py +0 -0
- chia/simulator/add_blocks_in_batches.py +54 -0
- chia/simulator/block_tools.py +2054 -0
- chia/simulator/full_node_simulator.py +794 -0
- chia/simulator/keyring.py +128 -0
- chia/simulator/setup_services.py +506 -0
- chia/simulator/simulator_constants.py +13 -0
- chia/simulator/simulator_full_node_rpc_api.py +99 -0
- chia/simulator/simulator_full_node_rpc_client.py +60 -0
- chia/simulator/simulator_protocol.py +29 -0
- chia/simulator/simulator_test_tools.py +164 -0
- chia/simulator/socket.py +24 -0
- chia/simulator/ssl_certs.py +114 -0
- chia/simulator/ssl_certs_1.py +697 -0
- chia/simulator/ssl_certs_10.py +697 -0
- chia/simulator/ssl_certs_2.py +697 -0
- chia/simulator/ssl_certs_3.py +697 -0
- chia/simulator/ssl_certs_4.py +697 -0
- chia/simulator/ssl_certs_5.py +697 -0
- chia/simulator/ssl_certs_6.py +697 -0
- chia/simulator/ssl_certs_7.py +697 -0
- chia/simulator/ssl_certs_8.py +697 -0
- chia/simulator/ssl_certs_9.py +697 -0
- chia/simulator/start_simulator.py +143 -0
- chia/simulator/wallet_tools.py +246 -0
- chia/ssl/__init__.py +0 -0
- chia/ssl/chia_ca.crt +19 -0
- chia/ssl/chia_ca.key +28 -0
- chia/ssl/create_ssl.py +249 -0
- chia/ssl/dst_root_ca.pem +20 -0
- chia/timelord/__init__.py +0 -0
- chia/timelord/iters_from_block.py +50 -0
- chia/timelord/timelord.py +1226 -0
- chia/timelord/timelord_api.py +138 -0
- chia/timelord/timelord_launcher.py +190 -0
- chia/timelord/timelord_state.py +244 -0
- chia/timelord/types.py +22 -0
- chia/types/__init__.py +0 -0
- chia/types/aliases.py +35 -0
- chia/types/block_protocol.py +20 -0
- chia/types/blockchain_format/__init__.py +0 -0
- chia/types/blockchain_format/classgroup.py +5 -0
- chia/types/blockchain_format/coin.py +28 -0
- chia/types/blockchain_format/foliage.py +8 -0
- chia/types/blockchain_format/pool_target.py +5 -0
- chia/types/blockchain_format/program.py +269 -0
- chia/types/blockchain_format/proof_of_space.py +135 -0
- chia/types/blockchain_format/reward_chain_block.py +6 -0
- chia/types/blockchain_format/serialized_program.py +5 -0
- chia/types/blockchain_format/sized_bytes.py +11 -0
- chia/types/blockchain_format/slots.py +9 -0
- chia/types/blockchain_format/sub_epoch_summary.py +5 -0
- chia/types/blockchain_format/tree_hash.py +72 -0
- chia/types/blockchain_format/vdf.py +86 -0
- chia/types/clvm_cost.py +13 -0
- chia/types/coin_record.py +43 -0
- chia/types/coin_spend.py +115 -0
- chia/types/condition_opcodes.py +73 -0
- chia/types/condition_with_args.py +16 -0
- chia/types/eligible_coin_spends.py +365 -0
- chia/types/end_of_slot_bundle.py +5 -0
- chia/types/fee_rate.py +38 -0
- chia/types/full_block.py +5 -0
- chia/types/generator_types.py +13 -0
- chia/types/header_block.py +5 -0
- chia/types/internal_mempool_item.py +18 -0
- chia/types/mempool_inclusion_status.py +9 -0
- chia/types/mempool_item.py +85 -0
- chia/types/mempool_submission_status.py +30 -0
- chia/types/mojos.py +7 -0
- chia/types/peer_info.py +64 -0
- chia/types/signing_mode.py +29 -0
- chia/types/spend_bundle.py +30 -0
- chia/types/spend_bundle_conditions.py +7 -0
- chia/types/transaction_queue_entry.py +55 -0
- chia/types/unfinished_block.py +5 -0
- chia/types/unfinished_header_block.py +37 -0
- chia/types/validation_state.py +14 -0
- chia/types/weight_proof.py +49 -0
- chia/util/__init__.py +0 -0
- chia/util/action_scope.py +168 -0
- chia/util/async_pool.py +226 -0
- chia/util/augmented_chain.py +134 -0
- chia/util/batches.py +42 -0
- chia/util/bech32m.py +126 -0
- chia/util/beta_metrics.py +119 -0
- chia/util/block_cache.py +56 -0
- chia/util/byte_types.py +12 -0
- chia/util/check_fork_next_block.py +33 -0
- chia/util/chia_logging.py +144 -0
- chia/util/chia_version.py +33 -0
- chia/util/collection.py +17 -0
- chia/util/condition_tools.py +201 -0
- chia/util/config.py +367 -0
- chia/util/cpu.py +22 -0
- chia/util/db_synchronous.py +23 -0
- chia/util/db_version.py +32 -0
- chia/util/db_wrapper.py +430 -0
- chia/util/default_root.py +27 -0
- chia/util/dump_keyring.py +93 -0
- chia/util/english.txt +2048 -0
- chia/util/errors.py +353 -0
- chia/util/file_keyring.py +469 -0
- chia/util/files.py +97 -0
- chia/util/full_block_utils.py +345 -0
- chia/util/generator_tools.py +72 -0
- chia/util/hash.py +31 -0
- chia/util/initial-config.yaml +694 -0
- chia/util/inline_executor.py +26 -0
- chia/util/ints.py +19 -0
- chia/util/ip_address.py +39 -0
- chia/util/json_util.py +37 -0
- chia/util/keychain.py +676 -0
- chia/util/keyring_wrapper.py +327 -0
- chia/util/limited_semaphore.py +41 -0
- chia/util/lock.py +49 -0
- chia/util/log_exceptions.py +32 -0
- chia/util/logging.py +36 -0
- chia/util/lru_cache.py +31 -0
- chia/util/math.py +20 -0
- chia/util/network.py +182 -0
- chia/util/paginator.py +48 -0
- chia/util/path.py +31 -0
- chia/util/permissions.py +20 -0
- chia/util/prev_transaction_block.py +21 -0
- chia/util/priority_mutex.py +95 -0
- chia/util/profiler.py +197 -0
- chia/util/recursive_replace.py +24 -0
- chia/util/safe_cancel_task.py +16 -0
- chia/util/service_groups.py +47 -0
- chia/util/setproctitle.py +22 -0
- chia/util/significant_bits.py +32 -0
- chia/util/ssl_check.py +213 -0
- chia/util/streamable.py +642 -0
- chia/util/task_referencer.py +59 -0
- chia/util/task_timing.py +382 -0
- chia/util/timing.py +67 -0
- chia/util/vdf_prover.py +30 -0
- chia/util/virtual_project_analysis.py +540 -0
- chia/util/ws_message.py +66 -0
- chia/wallet/__init__.py +0 -0
- chia/wallet/cat_wallet/__init__.py +0 -0
- chia/wallet/cat_wallet/cat_constants.py +75 -0
- chia/wallet/cat_wallet/cat_info.py +47 -0
- chia/wallet/cat_wallet/cat_outer_puzzle.py +120 -0
- chia/wallet/cat_wallet/cat_utils.py +164 -0
- chia/wallet/cat_wallet/cat_wallet.py +855 -0
- chia/wallet/cat_wallet/dao_cat_info.py +28 -0
- chia/wallet/cat_wallet/dao_cat_wallet.py +669 -0
- chia/wallet/cat_wallet/lineage_store.py +74 -0
- chia/wallet/cat_wallet/puzzles/__init__.py +0 -0
- chia/wallet/cat_wallet/puzzles/cat_truths.clib +31 -0
- chia/wallet/cat_wallet/puzzles/cat_v2.clsp +397 -0
- chia/wallet/cat_wallet/puzzles/cat_v2.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/delegated_tail.clsp +25 -0
- chia/wallet/cat_wallet/puzzles/delegated_tail.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp +15 -0
- chia/wallet/cat_wallet/puzzles/everything_with_signature.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp +26 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp +42 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_coin_id_or_singleton.clsp.hex +1 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp +24 -0
- chia/wallet/cat_wallet/puzzles/genesis_by_puzzle_hash.clsp.hex +1 -0
- chia/wallet/coin_selection.py +188 -0
- chia/wallet/conditions.py +1512 -0
- chia/wallet/dao_wallet/__init__.py +0 -0
- chia/wallet/dao_wallet/dao_info.py +61 -0
- chia/wallet/dao_wallet/dao_utils.py +811 -0
- chia/wallet/dao_wallet/dao_wallet.py +2119 -0
- chia/wallet/db_wallet/__init__.py +0 -0
- chia/wallet/db_wallet/db_wallet_puzzles.py +111 -0
- chia/wallet/derivation_record.py +30 -0
- chia/wallet/derive_keys.py +146 -0
- chia/wallet/did_wallet/__init__.py +0 -0
- chia/wallet/did_wallet/did_info.py +39 -0
- chia/wallet/did_wallet/did_wallet.py +1494 -0
- chia/wallet/did_wallet/did_wallet_puzzles.py +221 -0
- chia/wallet/did_wallet/puzzles/__init__.py +0 -0
- chia/wallet/did_wallet/puzzles/did_innerpuz.clsp +135 -0
- chia/wallet/did_wallet/puzzles/did_innerpuz.clsp.hex +1 -0
- chia/wallet/driver_protocol.py +26 -0
- chia/wallet/key_val_store.py +55 -0
- chia/wallet/lineage_proof.py +58 -0
- chia/wallet/nft_wallet/__init__.py +0 -0
- chia/wallet/nft_wallet/metadata_outer_puzzle.py +92 -0
- chia/wallet/nft_wallet/nft_info.py +120 -0
- chia/wallet/nft_wallet/nft_puzzles.py +305 -0
- chia/wallet/nft_wallet/nft_wallet.py +1687 -0
- chia/wallet/nft_wallet/ownership_outer_puzzle.py +101 -0
- chia/wallet/nft_wallet/puzzles/__init__.py +0 -0
- chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp +6 -0
- chia/wallet/nft_wallet/puzzles/create_nft_launcher_from_did.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp +6 -0
- chia/wallet/nft_wallet/puzzles/nft_intermediate_launcher.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp +30 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_default.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp +28 -0
- chia/wallet/nft_wallet/puzzles/nft_metadata_updater_updateable.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp +100 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_layer.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp +78 -0
- chia/wallet/nft_wallet/puzzles/nft_ownership_transfer_program_one_way_claim_with_royalties.clsp.hex +1 -0
- chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp +74 -0
- chia/wallet/nft_wallet/puzzles/nft_state_layer.clsp.hex +1 -0
- chia/wallet/nft_wallet/singleton_outer_puzzle.py +101 -0
- chia/wallet/nft_wallet/transfer_program_puzzle.py +82 -0
- chia/wallet/nft_wallet/uncurry_nft.py +217 -0
- chia/wallet/notification_manager.py +117 -0
- chia/wallet/notification_store.py +178 -0
- chia/wallet/outer_puzzles.py +84 -0
- chia/wallet/payment.py +33 -0
- chia/wallet/puzzle_drivers.py +118 -0
- chia/wallet/puzzles/__init__.py +0 -0
- chia/wallet/puzzles/augmented_condition.clsp +13 -0
- chia/wallet/puzzles/augmented_condition.clsp.hex +1 -0
- chia/wallet/puzzles/clawback/__init__.py +0 -0
- chia/wallet/puzzles/clawback/drivers.py +188 -0
- chia/wallet/puzzles/clawback/metadata.py +38 -0
- chia/wallet/puzzles/clawback/puzzle_decorator.py +67 -0
- chia/wallet/puzzles/condition_codes.clib +77 -0
- chia/wallet/puzzles/curry-and-treehash.clib +102 -0
- chia/wallet/puzzles/curry.clib +135 -0
- chia/wallet/puzzles/curry_by_index.clib +16 -0
- chia/wallet/puzzles/dao_cat_eve.clsp +17 -0
- chia/wallet/puzzles/dao_cat_eve.clsp.hex +1 -0
- chia/wallet/puzzles/dao_cat_launcher.clsp +36 -0
- chia/wallet/puzzles/dao_cat_launcher.clsp.hex +1 -0
- chia/wallet/puzzles/dao_finished_state.clsp +35 -0
- chia/wallet/puzzles/dao_finished_state.clsp.hex +1 -0
- chia/wallet/puzzles/dao_finished_state.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_lockup.clsp +288 -0
- chia/wallet/puzzles/dao_lockup.clsp.hex +1 -0
- chia/wallet/puzzles/dao_lockup.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_proposal.clsp +377 -0
- chia/wallet/puzzles/dao_proposal.clsp.hex +1 -0
- chia/wallet/puzzles/dao_proposal.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_proposal_timer.clsp +78 -0
- chia/wallet/puzzles/dao_proposal_timer.clsp.hex +1 -0
- chia/wallet/puzzles/dao_proposal_timer.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_proposal_validator.clsp +87 -0
- chia/wallet/puzzles/dao_proposal_validator.clsp.hex +1 -0
- chia/wallet/puzzles/dao_proposal_validator.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp +240 -0
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex +1 -0
- chia/wallet/puzzles/dao_spend_p2_singleton_v2.clsp.hex.sha256tree +1 -0
- chia/wallet/puzzles/dao_treasury.clsp +115 -0
- chia/wallet/puzzles/dao_treasury.clsp.hex +1 -0
- chia/wallet/puzzles/dao_update_proposal.clsp +44 -0
- chia/wallet/puzzles/dao_update_proposal.clsp.hex +1 -0
- chia/wallet/puzzles/deployed_puzzle_hashes.json +67 -0
- chia/wallet/puzzles/json.clib +25 -0
- chia/wallet/puzzles/load_clvm.py +161 -0
- chia/wallet/puzzles/merkle_utils.clib +18 -0
- chia/wallet/puzzles/notification.clsp +7 -0
- chia/wallet/puzzles/notification.clsp.hex +1 -0
- chia/wallet/puzzles/p2_1_of_n.clsp +22 -0
- chia/wallet/puzzles/p2_1_of_n.clsp.hex +1 -0
- chia/wallet/puzzles/p2_conditions.clsp +3 -0
- chia/wallet/puzzles/p2_conditions.clsp.hex +1 -0
- chia/wallet/puzzles/p2_conditions.py +26 -0
- chia/wallet/puzzles/p2_delegated_conditions.clsp +18 -0
- chia/wallet/puzzles/p2_delegated_conditions.clsp.hex +1 -0
- chia/wallet/puzzles/p2_delegated_conditions.py +21 -0
- chia/wallet/puzzles/p2_delegated_puzzle.clsp +19 -0
- chia/wallet/puzzles/p2_delegated_puzzle.clsp.hex +1 -0
- chia/wallet/puzzles/p2_delegated_puzzle.py +34 -0
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp +91 -0
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.clsp.hex +1 -0
- chia/wallet/puzzles/p2_delegated_puzzle_or_hidden_puzzle.py +160 -0
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp +108 -0
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.clsp.hex +1 -0
- chia/wallet/puzzles/p2_m_of_n_delegate_direct.py +21 -0
- chia/wallet/puzzles/p2_parent.clsp +19 -0
- chia/wallet/puzzles/p2_parent.clsp.hex +1 -0
- chia/wallet/puzzles/p2_puzzle_hash.clsp +18 -0
- chia/wallet/puzzles/p2_puzzle_hash.clsp.hex +1 -0
- chia/wallet/puzzles/p2_puzzle_hash.py +27 -0
- chia/wallet/puzzles/p2_singleton.clsp +30 -0
- chia/wallet/puzzles/p2_singleton.clsp.hex +1 -0
- chia/wallet/puzzles/p2_singleton_aggregator.clsp +81 -0
- chia/wallet/puzzles/p2_singleton_aggregator.clsp.hex +1 -0
- chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp +50 -0
- chia/wallet/puzzles/p2_singleton_or_delayed_puzhash.clsp.hex +1 -0
- chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp +47 -0
- chia/wallet/puzzles/p2_singleton_via_delegated_puzzle.clsp.hex +1 -0
- chia/wallet/puzzles/puzzle_utils.py +34 -0
- chia/wallet/puzzles/settlement_payments.clsp +49 -0
- chia/wallet/puzzles/settlement_payments.clsp.hex +1 -0
- chia/wallet/puzzles/sha256tree.clib +11 -0
- chia/wallet/puzzles/singleton_launcher.clsp +16 -0
- chia/wallet/puzzles/singleton_launcher.clsp.hex +1 -0
- chia/wallet/puzzles/singleton_top_layer.clsp +177 -0
- chia/wallet/puzzles/singleton_top_layer.clsp.hex +1 -0
- chia/wallet/puzzles/singleton_top_layer.py +296 -0
- chia/wallet/puzzles/singleton_top_layer_v1_1.clsp +107 -0
- chia/wallet/puzzles/singleton_top_layer_v1_1.clsp.hex +1 -0
- chia/wallet/puzzles/singleton_top_layer_v1_1.py +345 -0
- chia/wallet/puzzles/singleton_truths.clib +21 -0
- chia/wallet/puzzles/tails.py +348 -0
- chia/wallet/puzzles/utility_macros.clib +48 -0
- chia/wallet/signer_protocol.py +125 -0
- chia/wallet/singleton.py +106 -0
- chia/wallet/singleton_record.py +30 -0
- chia/wallet/trade_manager.py +1102 -0
- chia/wallet/trade_record.py +67 -0
- chia/wallet/trading/__init__.py +0 -0
- chia/wallet/trading/offer.py +702 -0
- chia/wallet/trading/trade_status.py +13 -0
- chia/wallet/trading/trade_store.py +526 -0
- chia/wallet/transaction_record.py +158 -0
- chia/wallet/transaction_sorting.py +14 -0
- chia/wallet/uncurried_puzzle.py +17 -0
- chia/wallet/util/__init__.py +0 -0
- chia/wallet/util/address_type.py +55 -0
- chia/wallet/util/blind_signer_tl.py +164 -0
- chia/wallet/util/clvm_streamable.py +203 -0
- chia/wallet/util/compute_hints.py +66 -0
- chia/wallet/util/compute_memos.py +43 -0
- chia/wallet/util/curry_and_treehash.py +91 -0
- chia/wallet/util/debug_spend_bundle.py +232 -0
- chia/wallet/util/merkle_tree.py +100 -0
- chia/wallet/util/merkle_utils.py +102 -0
- chia/wallet/util/new_peak_queue.py +82 -0
- chia/wallet/util/notifications.py +12 -0
- chia/wallet/util/peer_request_cache.py +174 -0
- chia/wallet/util/pprint.py +39 -0
- chia/wallet/util/puzzle_compression.py +95 -0
- chia/wallet/util/puzzle_decorator.py +100 -0
- chia/wallet/util/puzzle_decorator_type.py +7 -0
- chia/wallet/util/query_filter.py +59 -0
- chia/wallet/util/transaction_type.py +23 -0
- chia/wallet/util/tx_config.py +158 -0
- chia/wallet/util/wallet_sync_utils.py +351 -0
- chia/wallet/util/wallet_types.py +72 -0
- chia/wallet/vc_wallet/__init__.py +0 -0
- chia/wallet/vc_wallet/cr_cat_drivers.py +664 -0
- chia/wallet/vc_wallet/cr_cat_wallet.py +877 -0
- chia/wallet/vc_wallet/cr_outer_puzzle.py +102 -0
- chia/wallet/vc_wallet/cr_puzzles/__init__.py +0 -0
- chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp +3 -0
- chia/wallet/vc_wallet/cr_puzzles/conditions_w_fee_announce.clsp.hex +1 -0
- chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp +304 -0
- chia/wallet/vc_wallet/cr_puzzles/credential_restriction.clsp.hex +1 -0
- chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp +45 -0
- chia/wallet/vc_wallet/cr_puzzles/flag_proofs_checker.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_drivers.py +838 -0
- chia/wallet/vc_wallet/vc_puzzles/__init__.py +0 -0
- chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp +30 -0
- chia/wallet/vc_wallet/vc_puzzles/covenant_layer.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp +75 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_covenant_morpher.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp +32 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_transfer_program_covenant_adapter.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp +80 -0
- chia/wallet/vc_wallet/vc_puzzles/eml_update_metadata_with_DID.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp +163 -0
- chia/wallet/vc_wallet/vc_puzzles/exigent_metadata_layer.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp +16 -0
- chia/wallet/vc_wallet/vc_puzzles/p2_announced_delegated_puzzle.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp +74 -0
- chia/wallet/vc_wallet/vc_puzzles/standard_vc_backdoor_puzzle.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp +23 -0
- chia/wallet/vc_wallet/vc_puzzles/std_parent_morpher.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp +64 -0
- chia/wallet/vc_wallet/vc_puzzles/viral_backdoor.clsp.hex +1 -0
- chia/wallet/vc_wallet/vc_store.py +263 -0
- chia/wallet/vc_wallet/vc_wallet.py +638 -0
- chia/wallet/wallet.py +698 -0
- chia/wallet/wallet_action_scope.py +96 -0
- chia/wallet/wallet_blockchain.py +244 -0
- chia/wallet/wallet_coin_record.py +72 -0
- chia/wallet/wallet_coin_store.py +351 -0
- chia/wallet/wallet_info.py +35 -0
- chia/wallet/wallet_interested_store.py +188 -0
- chia/wallet/wallet_nft_store.py +279 -0
- chia/wallet/wallet_node.py +1765 -0
- chia/wallet/wallet_node_api.py +207 -0
- chia/wallet/wallet_pool_store.py +119 -0
- chia/wallet/wallet_protocol.py +90 -0
- chia/wallet/wallet_puzzle_store.py +396 -0
- chia/wallet/wallet_retry_store.py +70 -0
- chia/wallet/wallet_singleton_store.py +259 -0
- chia/wallet/wallet_spend_bundle.py +25 -0
- chia/wallet/wallet_state_manager.py +2819 -0
- chia/wallet/wallet_transaction_store.py +496 -0
- chia/wallet/wallet_user_store.py +110 -0
- chia/wallet/wallet_weight_proof_handler.py +126 -0
- chia_blockchain-2.5.1rc1.dist-info/LICENSE +201 -0
- chia_blockchain-2.5.1rc1.dist-info/METADATA +156 -0
- chia_blockchain-2.5.1rc1.dist-info/RECORD +1042 -0
- chia_blockchain-2.5.1rc1.dist-info/WHEEL +4 -0
- chia_blockchain-2.5.1rc1.dist-info/entry_points.txt +17 -0
- mozilla-ca/cacert.pem +3611 -0
chia/util/keychain.py
ADDED
|
@@ -0,0 +1,676 @@
|
|
|
1
|
+
# Package: utils
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
|
|
5
|
+
import sys
|
|
6
|
+
import unicodedata
|
|
7
|
+
from collections.abc import Iterator
|
|
8
|
+
from dataclasses import dataclass
|
|
9
|
+
from hashlib import pbkdf2_hmac
|
|
10
|
+
from pathlib import Path
|
|
11
|
+
from typing import Any, Literal, Optional, Union, overload
|
|
12
|
+
|
|
13
|
+
import importlib_resources
|
|
14
|
+
from bitstring import BitArray # pyright: reportMissingImports=false
|
|
15
|
+
from chia_rs import AugSchemeMPL, G1Element, PrivateKey # pyright: reportMissingImports=false
|
|
16
|
+
from chia_rs.sized_bytes import bytes32
|
|
17
|
+
from chia_rs.sized_ints import uint32
|
|
18
|
+
from typing_extensions import final
|
|
19
|
+
|
|
20
|
+
from chia.util.bech32m import bech32_decode, convertbits
|
|
21
|
+
from chia.util.byte_types import hexstr_to_bytes
|
|
22
|
+
from chia.util.errors import (
|
|
23
|
+
KeychainException,
|
|
24
|
+
KeychainFingerprintExists,
|
|
25
|
+
KeychainFingerprintNotFound,
|
|
26
|
+
KeychainKeyDataMismatch,
|
|
27
|
+
KeychainNotSet,
|
|
28
|
+
KeychainSecretsMissing,
|
|
29
|
+
KeychainUserNotFound,
|
|
30
|
+
)
|
|
31
|
+
from chia.util.file_keyring import Key
|
|
32
|
+
from chia.util.hash import std_hash
|
|
33
|
+
from chia.util.keyring_wrapper import KeyringWrapper
|
|
34
|
+
from chia.util.streamable import Streamable, streamable
|
|
35
|
+
|
|
36
|
+
CURRENT_KEY_VERSION = "1.8"
|
|
37
|
+
DEFAULT_USER = f"user-chia-{CURRENT_KEY_VERSION}" # e.g. user-chia-1.8
|
|
38
|
+
DEFAULT_SERVICE = f"chia-{DEFAULT_USER}" # e.g. chia-user-chia-1.8
|
|
39
|
+
MAX_KEYS = 101
|
|
40
|
+
MIN_PASSPHRASE_LEN = 8
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
def supports_os_passphrase_storage() -> bool:
|
|
44
|
+
return sys.platform in {"darwin", "win32", "cygwin"}
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
def passphrase_requirements() -> dict[str, Any]:
|
|
48
|
+
"""
|
|
49
|
+
Returns a dictionary specifying current passphrase requirements
|
|
50
|
+
"""
|
|
51
|
+
return {"is_optional": True, "min_length": MIN_PASSPHRASE_LEN} # lgtm [py/clear-text-logging-sensitive-data]
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
def set_keys_root_path(keys_root_path: Path) -> None:
|
|
55
|
+
"""
|
|
56
|
+
Used to set the keys_root_path prior to instantiating the KeyringWrapper shared instance.
|
|
57
|
+
"""
|
|
58
|
+
KeyringWrapper.set_keys_root_path(keys_root_path)
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
def bip39_word_list() -> str:
|
|
62
|
+
word_list_path = importlib_resources.files(__name__.rpartition(".")[0]).joinpath("english.txt")
|
|
63
|
+
contents: str = word_list_path.read_text(encoding="utf-8")
|
|
64
|
+
return contents
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
def generate_mnemonic() -> str:
|
|
68
|
+
mnemonic_bytes = bytes32.secret()
|
|
69
|
+
mnemonic = bytes_to_mnemonic(mnemonic_bytes)
|
|
70
|
+
return mnemonic
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
def bytes_to_mnemonic(mnemonic_bytes: bytes) -> str:
|
|
74
|
+
if len(mnemonic_bytes) not in {16, 20, 24, 28, 32}:
|
|
75
|
+
raise ValueError(
|
|
76
|
+
f"Data length should be one of the following: [16, 20, 24, 28, 32], but it is {len(mnemonic_bytes)}."
|
|
77
|
+
)
|
|
78
|
+
word_list = bip39_word_list().splitlines()
|
|
79
|
+
CS = len(mnemonic_bytes) // 4
|
|
80
|
+
|
|
81
|
+
checksum = BitArray(bytes(std_hash(mnemonic_bytes)))[:CS]
|
|
82
|
+
|
|
83
|
+
bitarray = BitArray(mnemonic_bytes) + checksum
|
|
84
|
+
mnemonics = []
|
|
85
|
+
assert len(bitarray) % 11 == 0
|
|
86
|
+
|
|
87
|
+
for i in range(0, len(bitarray) // 11):
|
|
88
|
+
start = i * 11
|
|
89
|
+
end = start + 11
|
|
90
|
+
bits = bitarray[start:end]
|
|
91
|
+
m_word_position = bits.uint
|
|
92
|
+
m_word = word_list[m_word_position]
|
|
93
|
+
mnemonics.append(m_word)
|
|
94
|
+
|
|
95
|
+
return " ".join(mnemonics)
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
def check_mnemonic_validity(mnemonic_str: str) -> bool:
|
|
99
|
+
mnemonic: list[str] = mnemonic_str.split(" ")
|
|
100
|
+
return len(mnemonic) in {12, 15, 18, 21, 24}
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
def mnemonic_from_short_words(mnemonic_str: str) -> str:
|
|
104
|
+
"""
|
|
105
|
+
Since the first 4 letters of each word is unique (or the full word, if less than 4 characters), and its common
|
|
106
|
+
practice to only store the first 4 letters of each word in many offline storage solutions, also support looking
|
|
107
|
+
up words by the first 4 characters
|
|
108
|
+
"""
|
|
109
|
+
mnemonic: list[str] = mnemonic_str.split(" ")
|
|
110
|
+
if len(mnemonic) not in {12, 15, 18, 21, 24}:
|
|
111
|
+
raise ValueError("Invalid mnemonic length")
|
|
112
|
+
|
|
113
|
+
four_char_dict = {word[:4]: word for word in bip39_word_list().splitlines()}
|
|
114
|
+
full_words: list[str] = []
|
|
115
|
+
for word in mnemonic:
|
|
116
|
+
full_word = four_char_dict.get(word[:4])
|
|
117
|
+
if full_word is None:
|
|
118
|
+
raise ValueError(f"{word!r} is not in the mnemonic dictionary; may be misspelled")
|
|
119
|
+
full_words.append(full_word)
|
|
120
|
+
|
|
121
|
+
return " ".join(full_words)
|
|
122
|
+
|
|
123
|
+
|
|
124
|
+
def bytes_from_mnemonic(mnemonic_str: str) -> bytes:
|
|
125
|
+
full_mnemonic_str = mnemonic_from_short_words(mnemonic_str)
|
|
126
|
+
mnemonic: list[str] = full_mnemonic_str.split(" ")
|
|
127
|
+
|
|
128
|
+
word_list = {word: i for i, word in enumerate(bip39_word_list().splitlines())}
|
|
129
|
+
bit_array = BitArray()
|
|
130
|
+
for i in range(0, len(mnemonic)):
|
|
131
|
+
word = mnemonic[i]
|
|
132
|
+
if word not in word_list:
|
|
133
|
+
raise ValueError(f"'{word}' is not in the mnemonic dictionary; may be misspelled")
|
|
134
|
+
value = word_list[word]
|
|
135
|
+
bit_array.append(BitArray(uint=value, length=11))
|
|
136
|
+
|
|
137
|
+
CS: int = len(mnemonic) // 3
|
|
138
|
+
ENT: int = len(mnemonic) * 11 - CS
|
|
139
|
+
assert len(bit_array) == len(mnemonic) * 11
|
|
140
|
+
assert ENT % 32 == 0
|
|
141
|
+
|
|
142
|
+
# mypy doesn't seem to understand the `property()` call used not as a decorator
|
|
143
|
+
entropy_bytes: bytes = bit_array[:ENT].bytes
|
|
144
|
+
checksum_bytes = bit_array[ENT:]
|
|
145
|
+
checksum = BitArray(std_hash(entropy_bytes))[:CS]
|
|
146
|
+
|
|
147
|
+
assert len(checksum_bytes) == CS
|
|
148
|
+
|
|
149
|
+
if checksum != checksum_bytes:
|
|
150
|
+
raise ValueError("Invalid order of mnemonic words")
|
|
151
|
+
|
|
152
|
+
return entropy_bytes
|
|
153
|
+
|
|
154
|
+
|
|
155
|
+
def mnemonic_to_seed(mnemonic: str) -> bytes:
|
|
156
|
+
"""
|
|
157
|
+
Uses BIP39 standard to derive a seed from entropy bytes.
|
|
158
|
+
"""
|
|
159
|
+
# If there are only ASCII characters (as typically expected in a seed phrase), we can check if its just shortened
|
|
160
|
+
# 4 letter versions of each word
|
|
161
|
+
if not any(ord(c) >= 128 for c in mnemonic):
|
|
162
|
+
mnemonic = mnemonic_from_short_words(mnemonic)
|
|
163
|
+
salt_str: str = "mnemonic"
|
|
164
|
+
salt = unicodedata.normalize("NFKD", salt_str).encode("utf-8")
|
|
165
|
+
mnemonic_normalized = unicodedata.normalize("NFKD", mnemonic).encode("utf-8")
|
|
166
|
+
seed = pbkdf2_hmac("sha512", mnemonic_normalized, salt, 2048)
|
|
167
|
+
|
|
168
|
+
assert len(seed) == 64
|
|
169
|
+
return seed
|
|
170
|
+
|
|
171
|
+
|
|
172
|
+
def default_keychain_user() -> str:
|
|
173
|
+
return DEFAULT_USER
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
def default_keychain_service() -> str:
|
|
177
|
+
return DEFAULT_SERVICE
|
|
178
|
+
|
|
179
|
+
|
|
180
|
+
def get_private_key_user(user: str, index: int) -> str:
|
|
181
|
+
"""
|
|
182
|
+
Returns the keychain user string for a key index.
|
|
183
|
+
"""
|
|
184
|
+
return f"wallet-{user}-{index}"
|
|
185
|
+
|
|
186
|
+
|
|
187
|
+
@final
|
|
188
|
+
@streamable
|
|
189
|
+
@dataclass(frozen=True)
|
|
190
|
+
class KeyDataSecrets(Streamable):
|
|
191
|
+
mnemonic: list[str]
|
|
192
|
+
entropy: bytes
|
|
193
|
+
private_key: PrivateKey
|
|
194
|
+
|
|
195
|
+
def __post_init__(self) -> None:
|
|
196
|
+
# This is redundant if `from_*` methods are used but its to make sure there can't be an `KeyDataSecrets`
|
|
197
|
+
# instance with an attribute mismatch for calculated cached values. Should be ok since we don't handle a lot of
|
|
198
|
+
# keys here.
|
|
199
|
+
mnemonic_str = self.mnemonic_str()
|
|
200
|
+
try:
|
|
201
|
+
bytes_from_mnemonic(mnemonic_str)
|
|
202
|
+
except Exception as e:
|
|
203
|
+
raise KeychainKeyDataMismatch("mnemonic") from e
|
|
204
|
+
if bytes_from_mnemonic(mnemonic_str) != self.entropy:
|
|
205
|
+
raise KeychainKeyDataMismatch("entropy")
|
|
206
|
+
if AugSchemeMPL.key_gen(mnemonic_to_seed(mnemonic_str)) != self.private_key:
|
|
207
|
+
raise KeychainKeyDataMismatch("private_key")
|
|
208
|
+
|
|
209
|
+
@classmethod
|
|
210
|
+
def from_mnemonic(cls, mnemonic: str) -> KeyDataSecrets:
|
|
211
|
+
return cls(
|
|
212
|
+
mnemonic=mnemonic.split(),
|
|
213
|
+
entropy=bytes_from_mnemonic(mnemonic),
|
|
214
|
+
private_key=AugSchemeMPL.key_gen(mnemonic_to_seed(mnemonic)),
|
|
215
|
+
)
|
|
216
|
+
|
|
217
|
+
@classmethod
|
|
218
|
+
def from_entropy(cls, entropy: bytes) -> KeyDataSecrets:
|
|
219
|
+
return cls.from_mnemonic(bytes_to_mnemonic(entropy))
|
|
220
|
+
|
|
221
|
+
@classmethod
|
|
222
|
+
def generate(cls) -> KeyDataSecrets:
|
|
223
|
+
return cls.from_mnemonic(generate_mnemonic())
|
|
224
|
+
|
|
225
|
+
def mnemonic_str(self) -> str:
|
|
226
|
+
return " ".join(self.mnemonic)
|
|
227
|
+
|
|
228
|
+
|
|
229
|
+
@final
|
|
230
|
+
@streamable
|
|
231
|
+
@dataclass(frozen=True)
|
|
232
|
+
class KeyData(Streamable):
|
|
233
|
+
fingerprint: uint32
|
|
234
|
+
public_key: G1Element
|
|
235
|
+
label: Optional[str]
|
|
236
|
+
secrets: Optional[KeyDataSecrets]
|
|
237
|
+
|
|
238
|
+
def __post_init__(self) -> None:
|
|
239
|
+
# This is redundant if `from_*` methods are used but its to make sure there can't be an `KeyData` instance with
|
|
240
|
+
# an attribute mismatch for calculated cached values. Should be ok since we don't handle a lot of keys here.
|
|
241
|
+
if self.secrets is not None and self.public_key != self.private_key.get_g1():
|
|
242
|
+
raise KeychainKeyDataMismatch("public_key")
|
|
243
|
+
if uint32(self.public_key.get_fingerprint()) != self.fingerprint:
|
|
244
|
+
raise KeychainKeyDataMismatch("fingerprint")
|
|
245
|
+
|
|
246
|
+
@classmethod
|
|
247
|
+
def from_mnemonic(cls, mnemonic: str, label: Optional[str] = None) -> KeyData:
|
|
248
|
+
private_key = AugSchemeMPL.key_gen(mnemonic_to_seed(mnemonic))
|
|
249
|
+
return cls(
|
|
250
|
+
fingerprint=uint32(private_key.get_g1().get_fingerprint()),
|
|
251
|
+
public_key=private_key.get_g1(),
|
|
252
|
+
label=label,
|
|
253
|
+
secrets=KeyDataSecrets.from_mnemonic(mnemonic),
|
|
254
|
+
)
|
|
255
|
+
|
|
256
|
+
@classmethod
|
|
257
|
+
def from_entropy(cls, entropy: bytes, label: Optional[str] = None) -> KeyData:
|
|
258
|
+
return cls.from_mnemonic(bytes_to_mnemonic(entropy), label)
|
|
259
|
+
|
|
260
|
+
@classmethod
|
|
261
|
+
def generate(cls, label: Optional[str] = None) -> KeyData:
|
|
262
|
+
return cls.from_mnemonic(generate_mnemonic(), label)
|
|
263
|
+
|
|
264
|
+
@property
|
|
265
|
+
def mnemonic(self) -> list[str]:
|
|
266
|
+
if self.secrets is None:
|
|
267
|
+
raise KeychainSecretsMissing()
|
|
268
|
+
return self.secrets.mnemonic
|
|
269
|
+
|
|
270
|
+
def mnemonic_str(self) -> str:
|
|
271
|
+
if self.secrets is None:
|
|
272
|
+
raise KeychainSecretsMissing()
|
|
273
|
+
return self.secrets.mnemonic_str()
|
|
274
|
+
|
|
275
|
+
@property
|
|
276
|
+
def entropy(self) -> bytes:
|
|
277
|
+
if self.secrets is None:
|
|
278
|
+
raise KeychainSecretsMissing()
|
|
279
|
+
return self.secrets.entropy
|
|
280
|
+
|
|
281
|
+
@property
|
|
282
|
+
def private_key(self) -> PrivateKey:
|
|
283
|
+
if self.secrets is None:
|
|
284
|
+
raise KeychainSecretsMissing()
|
|
285
|
+
return self.secrets.private_key
|
|
286
|
+
|
|
287
|
+
|
|
288
|
+
class Keychain:
|
|
289
|
+
"""
|
|
290
|
+
The keychain stores two types of keys: private keys, which are PrivateKeys from blspy,
|
|
291
|
+
and private key seeds, which are bytes objects that are used as a seed to construct
|
|
292
|
+
PrivateKeys. Private key seeds are converted to mnemonics when shown to users.
|
|
293
|
+
|
|
294
|
+
Both types of keys are stored as hex strings in the python keyring, and the implementation of
|
|
295
|
+
the keyring depends on OS. Both types of keys can be added, and get_private_keys returns a
|
|
296
|
+
list of all keys.
|
|
297
|
+
"""
|
|
298
|
+
|
|
299
|
+
def __init__(self, user: Optional[str] = None, service: Optional[str] = None):
|
|
300
|
+
self.user = user if user is not None else default_keychain_user()
|
|
301
|
+
self.service = service if service is not None else default_keychain_service()
|
|
302
|
+
|
|
303
|
+
keyring_wrapper: Optional[KeyringWrapper] = KeyringWrapper.get_shared_instance()
|
|
304
|
+
|
|
305
|
+
if keyring_wrapper is None:
|
|
306
|
+
raise KeychainNotSet("KeyringWrapper not set")
|
|
307
|
+
|
|
308
|
+
self.keyring_wrapper = keyring_wrapper
|
|
309
|
+
|
|
310
|
+
def _get_key_data(self, index: int, include_secrets: bool = True) -> KeyData:
|
|
311
|
+
"""
|
|
312
|
+
Returns the parsed keychain contents for a specific 'user' (key index). The content
|
|
313
|
+
is represented by the class `KeyData`.
|
|
314
|
+
"""
|
|
315
|
+
user = get_private_key_user(self.user, index)
|
|
316
|
+
key = self.keyring_wrapper.keyring.get_key(self.service, user)
|
|
317
|
+
if key is None or len(key.secret) == 0:
|
|
318
|
+
raise KeychainUserNotFound(self.service, user)
|
|
319
|
+
str_bytes = key.secret
|
|
320
|
+
|
|
321
|
+
public_key = G1Element.from_bytes(str_bytes[: G1Element.SIZE])
|
|
322
|
+
fingerprint = public_key.get_fingerprint()
|
|
323
|
+
if len(str_bytes) > G1Element.SIZE:
|
|
324
|
+
entropy = str_bytes[G1Element.SIZE : G1Element.SIZE + 32]
|
|
325
|
+
else:
|
|
326
|
+
entropy = None
|
|
327
|
+
|
|
328
|
+
return KeyData(
|
|
329
|
+
fingerprint=uint32(fingerprint),
|
|
330
|
+
public_key=public_key,
|
|
331
|
+
label=self.keyring_wrapper.keyring.get_label(fingerprint),
|
|
332
|
+
secrets=KeyDataSecrets.from_entropy(entropy) if include_secrets and entropy is not None else None,
|
|
333
|
+
)
|
|
334
|
+
|
|
335
|
+
def _get_free_private_key_index(self) -> int:
|
|
336
|
+
"""
|
|
337
|
+
Get the index of the first free spot in the keychain.
|
|
338
|
+
"""
|
|
339
|
+
index = 0
|
|
340
|
+
while True:
|
|
341
|
+
try:
|
|
342
|
+
self._get_key_data(index)
|
|
343
|
+
index += 1
|
|
344
|
+
except KeychainUserNotFound:
|
|
345
|
+
return index
|
|
346
|
+
|
|
347
|
+
@overload
|
|
348
|
+
def add_key(self, mnemonic_or_pk: str) -> PrivateKey: ...
|
|
349
|
+
|
|
350
|
+
@overload
|
|
351
|
+
def add_key(self, mnemonic_or_pk: str, label: Optional[str]) -> PrivateKey: ...
|
|
352
|
+
|
|
353
|
+
@overload
|
|
354
|
+
def add_key(self, mnemonic_or_pk: str, label: Optional[str], private: Literal[True]) -> PrivateKey: ...
|
|
355
|
+
|
|
356
|
+
@overload
|
|
357
|
+
def add_key(self, mnemonic_or_pk: str, label: Optional[str], private: Literal[False]) -> G1Element: ...
|
|
358
|
+
|
|
359
|
+
@overload
|
|
360
|
+
def add_key(self, mnemonic_or_pk: str, label: Optional[str], private: bool) -> Union[PrivateKey, G1Element]: ...
|
|
361
|
+
|
|
362
|
+
def add_key(
|
|
363
|
+
self, mnemonic_or_pk: str, label: Optional[str] = None, private: bool = True
|
|
364
|
+
) -> Union[PrivateKey, G1Element]:
|
|
365
|
+
"""
|
|
366
|
+
Adds a key to the keychain. The keychain itself will store the public key, and the entropy bytes (if given),
|
|
367
|
+
but not the passphrase.
|
|
368
|
+
"""
|
|
369
|
+
key: Union[PrivateKey, G1Element]
|
|
370
|
+
if private:
|
|
371
|
+
seed = mnemonic_to_seed(mnemonic_or_pk)
|
|
372
|
+
entropy = bytes_from_mnemonic(mnemonic_or_pk)
|
|
373
|
+
index = self._get_free_private_key_index()
|
|
374
|
+
key = AugSchemeMPL.key_gen(seed)
|
|
375
|
+
assert isinstance(key, PrivateKey)
|
|
376
|
+
pk = key.get_g1()
|
|
377
|
+
key_data = Key(bytes(pk) + entropy)
|
|
378
|
+
fingerprint = pk.get_fingerprint()
|
|
379
|
+
else:
|
|
380
|
+
index = self._get_free_private_key_index()
|
|
381
|
+
if mnemonic_or_pk.startswith("bls1238"):
|
|
382
|
+
_, data = bech32_decode(mnemonic_or_pk, max_length=94)
|
|
383
|
+
assert data is not None
|
|
384
|
+
pk_bytes = bytes(convertbits(data, 5, 8, False))
|
|
385
|
+
else:
|
|
386
|
+
pk_bytes = hexstr_to_bytes(mnemonic_or_pk)
|
|
387
|
+
key = G1Element.from_bytes(pk_bytes)
|
|
388
|
+
assert isinstance(key, G1Element)
|
|
389
|
+
key_data = Key(pk_bytes)
|
|
390
|
+
fingerprint = key.get_fingerprint()
|
|
391
|
+
|
|
392
|
+
if fingerprint in [pk.get_fingerprint() for pk in self.get_all_public_keys()]:
|
|
393
|
+
# Prevents duplicate add
|
|
394
|
+
raise KeychainFingerprintExists(fingerprint)
|
|
395
|
+
|
|
396
|
+
# Try to set the label first, it may fail if the label is invalid or already exists.
|
|
397
|
+
# This can probably just be moved into `FileKeyring.set_passphrase` after the legacy keyring stuff was dropped.
|
|
398
|
+
if label is not None:
|
|
399
|
+
self.keyring_wrapper.keyring.set_label(fingerprint, label)
|
|
400
|
+
|
|
401
|
+
try:
|
|
402
|
+
self.keyring_wrapper.keyring.set_key(
|
|
403
|
+
self.service,
|
|
404
|
+
get_private_key_user(self.user, index),
|
|
405
|
+
key_data,
|
|
406
|
+
)
|
|
407
|
+
except Exception:
|
|
408
|
+
if label is not None:
|
|
409
|
+
self.keyring_wrapper.keyring.delete_label(fingerprint)
|
|
410
|
+
raise
|
|
411
|
+
|
|
412
|
+
return key
|
|
413
|
+
|
|
414
|
+
def set_label(self, fingerprint: int, label: str) -> None:
|
|
415
|
+
"""
|
|
416
|
+
Assigns the given label to the first key with the given fingerprint.
|
|
417
|
+
"""
|
|
418
|
+
self.get_key(fingerprint) # raise if the fingerprint doesn't exist
|
|
419
|
+
self.keyring_wrapper.keyring.set_label(fingerprint, label)
|
|
420
|
+
|
|
421
|
+
def delete_label(self, fingerprint: int) -> None:
|
|
422
|
+
"""
|
|
423
|
+
Removes the label assigned to the key with the given fingerprint.
|
|
424
|
+
"""
|
|
425
|
+
self.keyring_wrapper.keyring.delete_label(fingerprint)
|
|
426
|
+
|
|
427
|
+
def _iterate_through_key_datas(
|
|
428
|
+
self, include_secrets: bool = True, skip_public_only: bool = False
|
|
429
|
+
) -> Iterator[KeyData]:
|
|
430
|
+
for index in range(MAX_KEYS):
|
|
431
|
+
try:
|
|
432
|
+
key_data = self._get_key_data(index, include_secrets=include_secrets)
|
|
433
|
+
if key_data is None or (skip_public_only and key_data.secrets is None):
|
|
434
|
+
continue
|
|
435
|
+
yield key_data
|
|
436
|
+
except KeychainUserNotFound:
|
|
437
|
+
pass
|
|
438
|
+
return None
|
|
439
|
+
|
|
440
|
+
def get_first_private_key(self) -> Optional[tuple[PrivateKey, bytes]]:
|
|
441
|
+
"""
|
|
442
|
+
Returns the first key in the keychain that has one of the passed in passphrases.
|
|
443
|
+
"""
|
|
444
|
+
for key_data in self._iterate_through_key_datas(skip_public_only=True):
|
|
445
|
+
return key_data.private_key, key_data.entropy
|
|
446
|
+
return None
|
|
447
|
+
|
|
448
|
+
def get_private_key_by_fingerprint(self, fingerprint: int) -> Optional[tuple[PrivateKey, bytes]]:
|
|
449
|
+
"""
|
|
450
|
+
Return first private key which have the given public key fingerprint.
|
|
451
|
+
"""
|
|
452
|
+
for key_data in self._iterate_through_key_datas(skip_public_only=True):
|
|
453
|
+
if key_data.fingerprint == fingerprint:
|
|
454
|
+
return key_data.private_key, key_data.entropy
|
|
455
|
+
return None
|
|
456
|
+
|
|
457
|
+
def get_all_private_keys(self) -> list[tuple[PrivateKey, bytes]]:
|
|
458
|
+
"""
|
|
459
|
+
Returns all private keys which can be retrieved, with the given passphrases.
|
|
460
|
+
A tuple of key, and entropy bytes (i.e. mnemonic) is returned for each key.
|
|
461
|
+
"""
|
|
462
|
+
all_keys: list[tuple[PrivateKey, bytes]] = []
|
|
463
|
+
for key_data in self._iterate_through_key_datas(skip_public_only=True):
|
|
464
|
+
all_keys.append((key_data.private_key, key_data.entropy))
|
|
465
|
+
return all_keys
|
|
466
|
+
|
|
467
|
+
def get_key(self, fingerprint: int, include_secrets: bool = False) -> KeyData:
|
|
468
|
+
"""
|
|
469
|
+
Return the KeyData of the first key which has the given public key fingerprint.
|
|
470
|
+
"""
|
|
471
|
+
for key_data in self._iterate_through_key_datas(include_secrets=include_secrets, skip_public_only=False):
|
|
472
|
+
if key_data.public_key.get_fingerprint() == fingerprint:
|
|
473
|
+
return key_data
|
|
474
|
+
raise KeychainFingerprintNotFound(fingerprint)
|
|
475
|
+
|
|
476
|
+
def get_keys(self, include_secrets: bool = False) -> list[KeyData]:
|
|
477
|
+
"""
|
|
478
|
+
Returns the KeyData of all keys which can be retrieved.
|
|
479
|
+
"""
|
|
480
|
+
all_keys: list[KeyData] = []
|
|
481
|
+
for key_data in self._iterate_through_key_datas(include_secrets=include_secrets, skip_public_only=False):
|
|
482
|
+
all_keys.append(key_data)
|
|
483
|
+
|
|
484
|
+
return all_keys
|
|
485
|
+
|
|
486
|
+
def get_all_public_keys(self) -> list[G1Element]:
|
|
487
|
+
"""
|
|
488
|
+
Returns all public keys.
|
|
489
|
+
"""
|
|
490
|
+
all_keys: list[G1Element] = []
|
|
491
|
+
for key_data in self._iterate_through_key_datas(skip_public_only=False):
|
|
492
|
+
all_keys.append(key_data.public_key)
|
|
493
|
+
|
|
494
|
+
return all_keys
|
|
495
|
+
|
|
496
|
+
def get_first_public_key(self) -> Optional[G1Element]:
|
|
497
|
+
"""
|
|
498
|
+
Returns the first public key.
|
|
499
|
+
"""
|
|
500
|
+
key_data = self.get_first_private_key()
|
|
501
|
+
return None if key_data is None else key_data[0].get_g1()
|
|
502
|
+
|
|
503
|
+
def delete_key_by_fingerprint(self, fingerprint: int) -> int:
|
|
504
|
+
"""
|
|
505
|
+
Deletes all keys which have the given public key fingerprint and returns how many keys were removed.
|
|
506
|
+
"""
|
|
507
|
+
removed = 0
|
|
508
|
+
# We duplicate ._iterate_through_key_datas due to needing the index
|
|
509
|
+
for index in range(MAX_KEYS):
|
|
510
|
+
try:
|
|
511
|
+
key_data = self._get_key_data(index, include_secrets=False)
|
|
512
|
+
if key_data is not None and key_data.fingerprint == fingerprint:
|
|
513
|
+
try:
|
|
514
|
+
self.keyring_wrapper.keyring.delete_label(key_data.fingerprint)
|
|
515
|
+
except (KeychainException, NotImplementedError):
|
|
516
|
+
# Just try to delete the label and move on if there wasn't one
|
|
517
|
+
pass
|
|
518
|
+
try:
|
|
519
|
+
self.keyring_wrapper.keyring.delete_key(self.service, get_private_key_user(self.user, index))
|
|
520
|
+
removed += 1
|
|
521
|
+
except Exception:
|
|
522
|
+
pass
|
|
523
|
+
except KeychainUserNotFound:
|
|
524
|
+
pass
|
|
525
|
+
return removed
|
|
526
|
+
|
|
527
|
+
def delete_keys(self, keys_to_delete: list[tuple[PrivateKey, bytes]]) -> None:
|
|
528
|
+
"""
|
|
529
|
+
Deletes all keys in the list.
|
|
530
|
+
"""
|
|
531
|
+
remaining_fingerprints = {x[0].get_g1().get_fingerprint() for x in keys_to_delete}
|
|
532
|
+
remaining_removals = len(remaining_fingerprints)
|
|
533
|
+
while len(remaining_fingerprints) > 0:
|
|
534
|
+
key_to_delete = remaining_fingerprints.pop()
|
|
535
|
+
if self.delete_key_by_fingerprint(key_to_delete) > 0:
|
|
536
|
+
remaining_removals -= 1
|
|
537
|
+
if remaining_removals > 0:
|
|
538
|
+
raise ValueError(f"{remaining_removals} keys could not be found for deletion")
|
|
539
|
+
|
|
540
|
+
def delete_all_keys(self) -> None:
|
|
541
|
+
"""
|
|
542
|
+
Deletes all keys from the keychain.
|
|
543
|
+
"""
|
|
544
|
+
for key_data in self._iterate_through_key_datas(include_secrets=False, skip_public_only=False):
|
|
545
|
+
self.delete_key_by_fingerprint(key_data.fingerprint)
|
|
546
|
+
|
|
547
|
+
@staticmethod
|
|
548
|
+
def is_keyring_locked() -> bool:
|
|
549
|
+
"""
|
|
550
|
+
Returns whether the keyring is in a locked state. If the keyring doesn't have a master passphrase set,
|
|
551
|
+
or if a master passphrase is set and the cached passphrase is valid, the keyring is "unlocked"
|
|
552
|
+
"""
|
|
553
|
+
# Unlocked: If a master passphrase isn't set, or if the cached passphrase is valid
|
|
554
|
+
if not Keychain.has_master_passphrase():
|
|
555
|
+
return False
|
|
556
|
+
|
|
557
|
+
passphrase = Keychain.get_cached_master_passphrase()
|
|
558
|
+
if passphrase is None:
|
|
559
|
+
return True
|
|
560
|
+
|
|
561
|
+
if Keychain.master_passphrase_is_valid(passphrase):
|
|
562
|
+
return False
|
|
563
|
+
|
|
564
|
+
# Locked: Everything else
|
|
565
|
+
return True
|
|
566
|
+
|
|
567
|
+
@staticmethod
|
|
568
|
+
def passphrase_is_optional() -> bool:
|
|
569
|
+
"""
|
|
570
|
+
Returns whether a user-supplied passphrase is optional, as specified by the passphrase requirements.
|
|
571
|
+
"""
|
|
572
|
+
return passphrase_requirements().get("is_optional", False) # type: ignore[no-any-return]
|
|
573
|
+
|
|
574
|
+
@staticmethod
|
|
575
|
+
def minimum_passphrase_length() -> int:
|
|
576
|
+
"""
|
|
577
|
+
Returns the minimum passphrase length, as specified by the passphrase requirements.
|
|
578
|
+
"""
|
|
579
|
+
return passphrase_requirements().get("min_length", 0) # type: ignore[no-any-return]
|
|
580
|
+
|
|
581
|
+
@staticmethod
|
|
582
|
+
def passphrase_meets_requirements(passphrase: Optional[str]) -> bool:
|
|
583
|
+
"""
|
|
584
|
+
Returns whether the provided passphrase satisfies the passphrase requirements.
|
|
585
|
+
"""
|
|
586
|
+
# Passphrase is not required and None was provided
|
|
587
|
+
if (passphrase is None or passphrase == "") and Keychain.passphrase_is_optional():
|
|
588
|
+
return True
|
|
589
|
+
|
|
590
|
+
# Passphrase meets the minimum length requirement
|
|
591
|
+
if passphrase is not None and len(passphrase) >= Keychain.minimum_passphrase_length():
|
|
592
|
+
return True
|
|
593
|
+
|
|
594
|
+
return False
|
|
595
|
+
|
|
596
|
+
@staticmethod
|
|
597
|
+
def has_master_passphrase() -> bool:
|
|
598
|
+
"""
|
|
599
|
+
Returns a bool indicating whether the underlying keyring data
|
|
600
|
+
is secured by a passphrase.
|
|
601
|
+
"""
|
|
602
|
+
return KeyringWrapper.get_shared_instance().has_master_passphrase()
|
|
603
|
+
|
|
604
|
+
@staticmethod
|
|
605
|
+
def master_passphrase_is_valid(passphrase: str, force_reload: bool = False) -> bool:
|
|
606
|
+
"""
|
|
607
|
+
Checks whether the provided passphrase can unlock the keyring. If force_reload
|
|
608
|
+
is true, the keyring payload will be re-read from the backing file. If false,
|
|
609
|
+
the passphrase will be checked against the in-memory payload.
|
|
610
|
+
"""
|
|
611
|
+
return KeyringWrapper.get_shared_instance().master_passphrase_is_valid(passphrase, force_reload=force_reload)
|
|
612
|
+
|
|
613
|
+
@staticmethod
|
|
614
|
+
def has_cached_passphrase() -> bool:
|
|
615
|
+
"""
|
|
616
|
+
Returns whether the master passphrase has been cached (it may need to be validated)
|
|
617
|
+
"""
|
|
618
|
+
return KeyringWrapper.get_shared_instance().has_cached_master_passphrase()
|
|
619
|
+
|
|
620
|
+
@staticmethod
|
|
621
|
+
def get_cached_master_passphrase() -> Optional[str]:
|
|
622
|
+
"""
|
|
623
|
+
Returns the cached master passphrase
|
|
624
|
+
"""
|
|
625
|
+
passphrase, _ = KeyringWrapper.get_shared_instance().get_cached_master_passphrase()
|
|
626
|
+
return passphrase
|
|
627
|
+
|
|
628
|
+
@staticmethod
|
|
629
|
+
def set_cached_master_passphrase(passphrase: Optional[str]) -> None:
|
|
630
|
+
"""
|
|
631
|
+
Caches the provided master passphrase
|
|
632
|
+
"""
|
|
633
|
+
KeyringWrapper.get_shared_instance().set_cached_master_passphrase(passphrase)
|
|
634
|
+
|
|
635
|
+
@staticmethod
|
|
636
|
+
def set_master_passphrase(
|
|
637
|
+
current_passphrase: Optional[str],
|
|
638
|
+
new_passphrase: str,
|
|
639
|
+
*,
|
|
640
|
+
passphrase_hint: Optional[str] = None,
|
|
641
|
+
save_passphrase: bool = False,
|
|
642
|
+
) -> None:
|
|
643
|
+
"""
|
|
644
|
+
Encrypts the keyring contents to new passphrase, provided that the current
|
|
645
|
+
passphrase can decrypt the contents
|
|
646
|
+
"""
|
|
647
|
+
KeyringWrapper.get_shared_instance().set_master_passphrase(
|
|
648
|
+
current_passphrase,
|
|
649
|
+
new_passphrase,
|
|
650
|
+
passphrase_hint=passphrase_hint,
|
|
651
|
+
save_passphrase=save_passphrase,
|
|
652
|
+
)
|
|
653
|
+
|
|
654
|
+
@staticmethod
|
|
655
|
+
def remove_master_passphrase(current_passphrase: Optional[str]) -> None:
|
|
656
|
+
"""
|
|
657
|
+
Removes the user-provided master passphrase, and replaces it with the default
|
|
658
|
+
master passphrase. The keyring contents will remain encrypted, but to the
|
|
659
|
+
default passphrase.
|
|
660
|
+
"""
|
|
661
|
+
KeyringWrapper.get_shared_instance().remove_master_passphrase(current_passphrase)
|
|
662
|
+
|
|
663
|
+
@staticmethod
|
|
664
|
+
def get_master_passphrase_hint() -> Optional[str]:
|
|
665
|
+
"""
|
|
666
|
+
Returns the passphrase hint from the keyring
|
|
667
|
+
"""
|
|
668
|
+
return KeyringWrapper.get_shared_instance().get_master_passphrase_hint()
|
|
669
|
+
|
|
670
|
+
@staticmethod
|
|
671
|
+
def set_master_passphrase_hint(current_passphrase: str, passphrase_hint: Optional[str]) -> None:
|
|
672
|
+
"""
|
|
673
|
+
Convenience method for setting/removing the passphrase hint. Requires the current
|
|
674
|
+
passphrase, as the passphrase hint is written as part of a passphrase update.
|
|
675
|
+
"""
|
|
676
|
+
Keychain.set_master_passphrase(current_passphrase, current_passphrase, passphrase_hint=passphrase_hint)
|