mirror of
https://github.com/Chia-Network/chia-blockchain.git
synced 2024-09-21 16:41:14 +03:00
89f7a4b3d6
* added clarifying comments * WIP test * added WIP test * Refine genesis challenge. Remove unnecessary pool_puzzle function * Sign spend. Remove create_member_spend. Rename state transition function to create_travel_spend * Rename create_member_spend to create_travel_spend * Add singleton id logging * Enhance logging for debugging * renaming * rephrase inside the puzzle * fixed signing and added some support functions * Fix issue with announcement * Progress spending the singleton * Fix arguments to pool_state_to_inner_puzzle call * Fix arguments to pool_state_to_inner_puzzle * Improve error message when wallet is not running * Remove misleading message about missing wallet process, when problem is the farmer by making poolnft command error out earlier * Fix parent coin info bug * Multiple state transitions in one block * Lint * Remove assert * Fix incorrect p2_singleton_ph calculation (thanks nil00) * Update waiting room puzzle to accept genesis_challenge * Update calls to create_waiting * Go to waiting state from committed state * Augment debug_spend_bundle * fix 2 bugs in wallet * Fix lint * fix bad_agg_sig bug * Tests and lint * remove breakpoint * fix clvm tests for new hexs and hashs * Fixed a bug in the coin store that was probably from merging. (#6577) * Fixed a bug in the coin store that was probably from merging. * The exception doesn't need to be there * CI Lint fix * Added lifecycle tests for pooling drivers (#6610) * Ms.poolabsorb (#6615) * Support for absorbing rewards in pools (untested) * Style improvements * More work on absorb * Revert default root and remove log * Revert small plots * Use real sub slot iters * Update types * debug1 * Fix bugs * fix output of agg sig log messages * Make fewer calls to pw_status in test * remove old comment * logging and state management * logging * small bug fix & rename for accuracy * format * Fix types for uncurry function * lint * Update test to use exceptions * Change assumptions about self-pooling in lifecycle test * Install types for mypy * Revert "Install types for mypy" This reverts commita82dcb712a
. * install types for mypy * install types for mypy * More keys * Remove flags requiring interactive prompts * Change initial spend to waiting room if self-pooling * lint * lint * linting * Refactor test * Use correct value in log message * update p2_singleton_or_delated_puzhash * initial version of pool wallet with p2_singleton_or_delay * run black formatting * fix rebase wonkiness * fix announcement code in p2_singleton_or_delayed * removed redundant defaulting standardised hexstr handling * lint fixes * Fixed pool lifecycle tests to current standards, but discovered tests are not validating signatures * Signatures validate on this test now although the test still does not check it. * Lint fix * Fixed plotnft show and linting errors * fixed failing farmer/harvester rpc test * lint fix * Commenting out some outdated tests * Updated test coverage * lint fix * Some minor P2singleton improvements (#6325) * Improve some debugging tools. * Tidy pool clvm. * Use `SINGLETON_STRUCT`. Remove unused `and` macro. * Use better name `SINGLETON_MOD_HASH`. * Finish lifecycle test suite. * Fixing for merge with chia-blockchain/pools_delayed_puzzle (#72) Co-authored-by: Matt Hauff <quexington@gmail.com> * Default delay time was being set incorrectly * Extracted get_delayed_puz_info_from_launcher_spend to driver code * Ms.taproot plot2 (#6692) * Start work on adding taproot to new plots * Fix issue in block_tools * new test-cache * Lint * DID fixexs * Fix other tests * Python black * Fix full node store test * Ensure block index <= 128 bits. * fix test_pool_config test * fix comments in pool_config and in chialisp files * self_pool -> pool -> self_pool * Implement leaving pools * Fix conflicts with main via mini-rebase * Fixup rebase mistakes * Bring in Mariano's node discovery chagnes from pools.dev * Fix adapters - Thanks Richard * build tests * Add pools tests * Disable DID tests * farmer|protocol: Some renaming related to the pool protocol * farmer: Use `None` instead of `{}` and add local `pool_state` * protocol|farmer: Introduce and use `PoolErrorCode` * rename: `pool_payout_instructions` -> `payout_instructions` * refactor: `AuthenticationKeyInfo` -> `authentication_key` * refactor: Move `launcher_id` up * rename: Some variable name changes * rename: `points_balance` -> `points` * format: Squash aggregation into one line * farmer: Make `update_pool_state` public * farmer: Print traceback if `update_pool_state` fails * farmer: Periodically call `GET /pool_info`, add `_pool_get_pool_info` * farmer: Add `authentication_token_timeout` to `pool_state` Fetch it from `GET /pool_info` * protocol|farmer: Implement support for `GET|POST|PUT /farmer` * farmer: Make use of `GET|POST /farmer` - To make the farmer known by the pool - To update local balance/difficulty from the pool periodically * farmer|protocol: Adjust `POST /partial` to match the latest spec * farmer: Hash messages before signing * pools: Drop unused code * farmer: Fix aggregation of partial signatures * farmer: support self pooling, don't pool if url=="" * wallet: return uint64 for delay time, instead of bytes * pool: add error code for delay time too short * farmer: cleaner logging when no connection to pool * farmer: add harvester node id to pool protocol * Rename method (test fix) and lint fix * Change errors to warnings (pool communication) * Remove pool callbacks on a reorg * farmer: Continue earlier when no pool URL is provided * farmer: Print method in log * farmer: Handle exceptions for all pool endpoint calls * farmer|protocol: Keep track of failed requests to the pool * farmer: Fix typo which caused issue with pooling * wallet: simplify solution_to_extra_data * tests: Comment out DID tests which are not working yet * Remove DID Wallet test workflows * Return launcher_id when creating Pool Wallet * Name p2_singleton_puzzle_hash correctly * Improve 'test_singleton_lifecycle_fast.py'. * Make test more robust in the face of asynchronous adversity * Add commandline cmds for joining and leaving pools * Fix poolnft leave params * Remove redundant assignment brought in from main * Remove unneeded code * Style and parsimony * pool_puzzles: Check was wrong, and bad naming * format: Fix linting * format: Remove log and rename variable * pool-wallet: Fix self pooling with multiple pool wallets. Don't remove interested puzzle_hash * gui: Use pools branch * format: fix lint * Remove ununsed code, improve initial_pool_state_from_dict * farmer: Instantly update the config, when config file changes * format: Speed up loading of the authentication key * logging: less annoying logging * Test pool NFT creation directly to pool * Test switching pools without self-farming in between * lint * pooling: Use integer for protocol version (#6797) * pooling: Use integer for protocol version * pooling: Fix import * Update GUI commit * Ms.login2 (#6804) * pooling: Login WIP * pooling: add RPC for get_link * dont use timeout * pooling: rename to get_login_link * format: remove logging * Fix SES test * Required cli argument Co-authored-by: almog <almogdepaz@gmail.com> * farmer|protocols: Rename `current_difficulty` for `POST /partial` (#6807) * Fix to farm summary * Use target_puzzlehash param name in RPC call * Pool test coverage (#6782) * Improvement in test coverage and typing * Added an extra absorb to the pool lifecycle test (only works when merged with https://github.com/Chia-Network/chia-blockchain/pull/6733) * Added new drivers for the p2_singleton puzzles * Added new tests and test coverage for singletons * organize pools testing directory * black formatting * black formatting in venv * lint fix * Update CI tests * Fixing tests post rebase * lint fix * Minor readability fix Co-authored-by: matt <matt@chia.net> * farmer: Drop `target_puzzle_hash` from `GET /farmer` and `GET /login` (#6816) * Allow creation of PlotNFTs in self-farming state * gui: Fix install with more RAM (#6821) * Allow implicit payout_address in self-pool state, improve error messages and param ergonomics * print units in non-standard wallets correctly * Fix farmer import * Make syncing message in CLI more intuitive like the GUI * Fix linting and show header hash instead of height * gui: Update to 725071236eff8c81d5b267dc8eb69d7e03f3df8c * Revert "Merge" This reverts commit23a1e688c5
, reversing changes made toa850246c6f
. * Revert "Revert "Merge"" This reverts commit680331859f
. * Treat tx_record as Dict. Refactor tx submission * Also add passed-in coin spends when processing new blocks in reconsider_peak * Test utilities had moved * Fix import of moved block_tools * Potentially fix yaml * Previously didn't take the right part of this change * Add -y flag, improve commandline plotnft handling * Fix typo * Add -y flag to plotnft create * pool_wallet: Restore from DB properly * wallet: ignore bad pool configs * Reduce memory * pool_wallet: Add claim command * pool_wallet: Set transaction records to confirmed * wallet: Fix bug in transaction cache * Formatting and remove log * pool_wallet: CLI balance and improvements to plotnft_funcs.py * pool_wallet: Simplify, and fix issue with double submission * pool_wallet: Fix tests * pool_wallet: Don't allow switching before relative lock height * update gui * change to 3000 mem * Correct sense of -y flag for self-pooling * cli: Display payout instructions for pool * pool_wallet: Don't create massive transactions * cli: Improvements to plotnft * pool_wallet: Get correct pool state * pool_wallet: Use last transaction block to prevent condition failure * Add block height for current state * Add outstanding unconfirmed transactions to pw_status * Refine command line plotnft show pending transactions * Fix tests by using the correct output from pw_status * Try to fix windows build * Print expected leave height * label pool urls * pool_wallet: Don't include pool 1.75 rewards in total * wallet: Add RPC and CLI for deleting unconfirmed transactions for a wallet * pool_wallet: If farming to a pool, show 0 balance in wallet * pool_wallet: Show error message if invalid state, in CLI * pool_wallet: Don't allow switching if there are pending unconfirmed transactions * tests: Clean up pool test logging * tests: Fix lint * Changed the pool innerpuzzes (#6802) * overload solutions for pool_innerpuz parameters * Fix tests for reduced size puzzles * deleted messy deprecated test * Fix lint. * fix bug where spend types were the wrong way around * merge with richard's lint fix * fix wallet bug remove unnecessary signature add defun-inline for clarity * Swap to defun for absorb case Use cons box for member innerpuz solution * fix if statement for cons box p1 * remove unnecessary solution arg * quick innerpuz fix to make tests pass * Switch to key-value pairs Undo cons box solution in pool_member inner puzzle * fix singleton lifecycle test * added some comments to calrify the meaning on "ps" * lint fix * reduce label size, search for label when reconstructing from solution * no need to keep looping if `p` found * lint fix * Removed unecessary defun-inline and changed hyphens to underscores * Changed created_coin_value_or_0 to an inline function * Changed morph_condition to an inline function * Added a comment for odd_cons_m113 * Rename output_odd and odd_output_found * Add inline functions to document the lineage proof values * Stager two rewrite * Added an ASSER_MY_AMOUNT to p2_singleton_or_delayed * Extract truth functionality to singleton_truths.clib * Fix tree hashes * Changed truths to a struct rather than a list. * fix test_singletons update did_innerpuz * recompile did_innerpuz * fix a log error * Renamed variable and factored out code per @richardkiss * lint fix * switch launcher extra_data to key_value pairs * fix parsing of new format of extra_data in launcher solution * fix broken test for new launcher solution format * remove bare raise Co-authored-by: Richard Kiss <him@richardkiss.com> Co-authored-by: Matt Hauff <quexington@gmail.com> * Also add passed-in coin spends when processing new blocks in reconsider_peak (#6898) Co-authored-by: Adam Kelly <aqk> * Moved debug_spend_bundle and added it to the SpendBundle object (#6840) * Moved debug_spend_bundle and added it to the SpendBundle object * Remove problematic typing * Add testnet config * wallet: Memory would get corrupted if there was an error (#6902) * wallet: Memory would get corrupted if there was an error * wallet: Use block_record * wallet: Add records in a full fork too * wallet: remove unnecessary arguments in CC and DID * add to cache, revert if transaction fails Co-authored-by: Yostra <straya@chia.net> * Improve comment * pool_wallet: Fix driver bug * wallet: Fix memory corruption * gui: Update to latest * Increase memory size * tests: Add test for absorbing from pool * small fix in solution_to_extra_data * Fixed incorrect function name * pooling: Fix EOS handling in full node * [pools.testnet9]add post /partial and /farmer header (#6957) * Update farmer.py add post header * Update farmer_api.py add post header * Update chia/farmer/farmer.py Co-authored-by: dustinface <35775977+xdustinface@users.noreply.github.com> * Update chia/farmer/farmer_api.py Co-authored-by: dustinface <35775977+xdustinface@users.noreply.github.com> Co-authored-by: Mariano Sorgente <3069354+mariano54@users.noreply.github.com> Co-authored-by: dustinface <35775977+xdustinface@users.noreply.github.com> * Fix lint and cleanup farmer.py * farmer: Fix linting issues (#7010) * Handle the case of incorrectly formatted PoolState data returned from inner singleton * wallet: Resubmit transaction if not successful, rename to new_transaction_block_callback (#7008) * Fix lint in pool_puzzles * pooling: Fix owner private key lookup, and remove unnecessary argument * pooling: Clear target state on `delete_unconfirmed_transactions` * Lint * Fix non-deterministic test * Slight cleanup clvm driver code (#7028) * Return None when a deserialized CLVM structure does not fit the expected format of var-value pair for singleton data * lint Co-authored-by: Adam Kelly <aqk> * Revert "Add testnet config" This reverts commit9812442724
. Co-authored-by: matt <matt@chia.net> Co-authored-by: Adam Kelly <aqk@aqk.im> Co-authored-by: Mariano Sorgente <sorgente711@gmail.com> Co-authored-by: Matt Hauff <quexington@gmail.com> Co-authored-by: Mariano Sorgente <3069354+mariano54@users.noreply.github.com> Co-authored-by: Adam <aqk@Adams-MacBook-Pro.local> Co-authored-by: Adam Kelly <aqk> Co-authored-by: Richard Kiss <him@richardkiss.com> Co-authored-by: xdustinface <xdustinfacex@gmail.com> Co-authored-by: almog <almogdepaz@gmail.com> Co-authored-by: dustinface <35775977+xdustinface@users.noreply.github.com> Co-authored-by: Earle Lowe <e.lowe@chia.net> Co-authored-by: arvidn <arvid@libtorrent.org> Co-authored-by: willi123yao <willi123yao@gmail.com> Co-authored-by: arty <art.yerkes@gmail.com> Co-authored-by: William Blanke <wjb98672@gmail.com> Co-authored-by: matt-o-how <48453825+matt-o-how@users.noreply.github.com> Co-authored-by: Chris Marslender <chrismarslender@gmail.com> Co-authored-by: Yostra <straya@chia.net> Co-authored-by: DouCrazy <43004977+lpf763827726@users.noreply.github.com>
323 lines
15 KiB
Python
323 lines
15 KiB
Python
from typing import Any
|
|
|
|
import click
|
|
|
|
|
|
async def show_async(
|
|
rpc_port: int,
|
|
state: bool,
|
|
show_connections: bool,
|
|
exit_node: bool,
|
|
add_connection: str,
|
|
remove_connection: str,
|
|
block_header_hash_by_height: str,
|
|
block_by_header_hash: str,
|
|
) -> None:
|
|
import aiohttp
|
|
import time
|
|
import traceback
|
|
|
|
from time import localtime, struct_time
|
|
from typing import List, Optional
|
|
from chia.consensus.block_record import BlockRecord
|
|
from chia.rpc.full_node_rpc_client import FullNodeRpcClient
|
|
from chia.server.outbound_message import NodeType
|
|
from chia.types.full_block import FullBlock
|
|
from chia.util.bech32m import encode_puzzle_hash
|
|
from chia.util.byte_types import hexstr_to_bytes
|
|
from chia.util.config import load_config
|
|
from chia.util.default_root import DEFAULT_ROOT_PATH
|
|
from chia.util.ints import uint16
|
|
from chia.util.misc import format_bytes
|
|
|
|
try:
|
|
config = load_config(DEFAULT_ROOT_PATH, "config.yaml")
|
|
self_hostname = config["self_hostname"]
|
|
if rpc_port is None:
|
|
rpc_port = config["full_node"]["rpc_port"]
|
|
client = await FullNodeRpcClient.create(self_hostname, uint16(rpc_port), DEFAULT_ROOT_PATH, config)
|
|
|
|
if state:
|
|
blockchain_state = await client.get_blockchain_state()
|
|
if blockchain_state is None:
|
|
print("There is no blockchain found yet. Try again shortly")
|
|
return None
|
|
peak: Optional[BlockRecord] = blockchain_state["peak"]
|
|
difficulty = blockchain_state["difficulty"]
|
|
sub_slot_iters = blockchain_state["sub_slot_iters"]
|
|
synced = blockchain_state["sync"]["synced"]
|
|
sync_mode = blockchain_state["sync"]["sync_mode"]
|
|
total_iters = peak.total_iters if peak is not None else 0
|
|
num_blocks: int = 10
|
|
|
|
if synced:
|
|
print("Current Blockchain Status: Full Node Synced")
|
|
print("\nPeak: Hash:", peak.header_hash if peak is not None else "")
|
|
elif peak is not None and sync_mode:
|
|
sync_max_block = blockchain_state["sync"]["sync_tip_height"]
|
|
sync_current_block = blockchain_state["sync"]["sync_progress_height"]
|
|
print(f"Current Blockchain Status: Syncing {sync_current_block}/{sync_max_block}.")
|
|
print("Peak: Hash:", peak.header_hash if peak is not None else "")
|
|
elif peak is not None:
|
|
print(f"Current Blockchain Status: Not Synced. Peak height: {peak.height}")
|
|
else:
|
|
print("\nSearching for an initial chain\n")
|
|
print("You may be able to expedite with 'chia show -a host:port' using a known node.\n")
|
|
|
|
if peak is not None:
|
|
if peak.is_transaction_block:
|
|
peak_time = peak.timestamp
|
|
else:
|
|
peak_hash = peak.header_hash
|
|
curr = await client.get_block_record(peak_hash)
|
|
while curr is not None and not curr.is_transaction_block:
|
|
curr = await client.get_block_record(curr.prev_hash)
|
|
peak_time = curr.timestamp
|
|
peak_time_struct = struct_time(localtime(peak_time))
|
|
|
|
print(
|
|
" Time:",
|
|
f"{time.strftime('%a %b %d %Y %T %Z', peak_time_struct)}",
|
|
f" Height: {peak.height:>10}\n",
|
|
)
|
|
|
|
print("Estimated network space: ", end="")
|
|
print(format_bytes(blockchain_state["space"]))
|
|
print(f"Current difficulty: {difficulty}")
|
|
print(f"Current VDF sub_slot_iters: {sub_slot_iters}")
|
|
print("Total iterations since the start of the blockchain:", total_iters)
|
|
print("")
|
|
print(" Height: | Hash:")
|
|
|
|
added_blocks: List[BlockRecord] = []
|
|
curr = await client.get_block_record(peak.header_hash)
|
|
while curr is not None and len(added_blocks) < num_blocks and curr.height > 0:
|
|
added_blocks.append(curr)
|
|
curr = await client.get_block_record(curr.prev_hash)
|
|
|
|
for b in added_blocks:
|
|
print(f"{b.height:>9} | {b.header_hash}")
|
|
else:
|
|
print("Blockchain has no blocks yet")
|
|
|
|
# if called together with show_connections, leave a blank line
|
|
if show_connections:
|
|
print("")
|
|
if show_connections:
|
|
connections = await client.get_connections()
|
|
print("Connections:")
|
|
print(
|
|
"Type IP Ports NodeID Last Connect"
|
|
+ " MiB Up|Dwn"
|
|
)
|
|
for con in connections:
|
|
last_connect_tuple = struct_time(localtime(con["last_message_time"]))
|
|
last_connect = time.strftime("%b %d %T", last_connect_tuple)
|
|
mb_down = con["bytes_read"] / (1024 * 1024)
|
|
mb_up = con["bytes_written"] / (1024 * 1024)
|
|
|
|
host = con["peer_host"]
|
|
# Strip IPv6 brackets
|
|
if host[0] == "[":
|
|
host = host[1:39]
|
|
# Nodetype length is 9 because INTRODUCER will be deprecated
|
|
if NodeType(con["type"]) is NodeType.FULL_NODE:
|
|
peak_height = con["peak_height"]
|
|
peak_hash = con["peak_hash"]
|
|
if peak_hash is None:
|
|
peak_hash = "No Info"
|
|
if peak_height is None:
|
|
peak_height = 0
|
|
con_str = (
|
|
f"{NodeType(con['type']).name:9} {host:38} "
|
|
f"{con['peer_port']:5}/{con['peer_server_port']:<5}"
|
|
f" {con['node_id'].hex()[:8]}... "
|
|
f"{last_connect} "
|
|
f"{mb_up:7.1f}|{mb_down:<7.1f}"
|
|
f"\n "
|
|
f"-SB Height: {peak_height:8.0f} -Hash: {peak_hash[2:10]}..."
|
|
)
|
|
else:
|
|
con_str = (
|
|
f"{NodeType(con['type']).name:9} {host:38} "
|
|
f"{con['peer_port']:5}/{con['peer_server_port']:<5}"
|
|
f" {con['node_id'].hex()[:8]}... "
|
|
f"{last_connect} "
|
|
f"{mb_up:7.1f}|{mb_down:<7.1f}"
|
|
)
|
|
print(con_str)
|
|
# if called together with state, leave a blank line
|
|
if state:
|
|
print("")
|
|
if exit_node:
|
|
node_stop = await client.stop_node()
|
|
print(node_stop, "Node stopped")
|
|
if add_connection:
|
|
if ":" not in add_connection:
|
|
print("Enter a valid IP and port in the following format: 10.5.4.3:8000")
|
|
else:
|
|
ip, port = (
|
|
":".join(add_connection.split(":")[:-1]),
|
|
add_connection.split(":")[-1],
|
|
)
|
|
print(f"Connecting to {ip}, {port}")
|
|
try:
|
|
await client.open_connection(ip, int(port))
|
|
except Exception:
|
|
print(f"Failed to connect to {ip}:{port}")
|
|
if remove_connection:
|
|
result_txt = ""
|
|
if len(remove_connection) != 8:
|
|
result_txt = "Invalid NodeID. Do not include '.'"
|
|
else:
|
|
connections = await client.get_connections()
|
|
for con in connections:
|
|
if remove_connection == con["node_id"].hex()[:8]:
|
|
print("Attempting to disconnect", "NodeID", remove_connection)
|
|
try:
|
|
await client.close_connection(con["node_id"])
|
|
except Exception:
|
|
result_txt = f"Failed to disconnect NodeID {remove_connection}"
|
|
else:
|
|
result_txt = f"NodeID {remove_connection}... {NodeType(con['type']).name} "
|
|
f"{con['peer_host']} disconnected"
|
|
elif result_txt == "":
|
|
result_txt = f"NodeID {remove_connection}... not found"
|
|
print(result_txt)
|
|
if block_header_hash_by_height != "":
|
|
block_header = await client.get_block_record_by_height(block_header_hash_by_height)
|
|
if block_header is not None:
|
|
print(f"Header hash of block {block_header_hash_by_height}: " f"{block_header.header_hash.hex()}")
|
|
else:
|
|
print("Block height", block_header_hash_by_height, "not found")
|
|
if block_by_header_hash != "":
|
|
block: Optional[BlockRecord] = await client.get_block_record(hexstr_to_bytes(block_by_header_hash))
|
|
full_block: Optional[FullBlock] = await client.get_block(hexstr_to_bytes(block_by_header_hash))
|
|
# Would like to have a verbose flag for this
|
|
if block is not None:
|
|
assert full_block is not None
|
|
prev_b = await client.get_block_record(block.prev_hash)
|
|
if prev_b is not None:
|
|
difficulty = block.weight - prev_b.weight
|
|
else:
|
|
difficulty = block.weight
|
|
if block.is_transaction_block:
|
|
assert full_block.transactions_info is not None
|
|
block_time = struct_time(
|
|
localtime(
|
|
full_block.foliage_transaction_block.timestamp
|
|
if full_block.foliage_transaction_block
|
|
else None
|
|
)
|
|
)
|
|
block_time_string = time.strftime("%a %b %d %Y %T %Z", block_time)
|
|
cost = str(full_block.transactions_info.cost)
|
|
tx_filter_hash = "Not a transaction block"
|
|
if full_block.foliage_transaction_block:
|
|
tx_filter_hash = full_block.foliage_transaction_block.filter_hash
|
|
fees: Any = block.fees
|
|
else:
|
|
block_time_string = "Not a transaction block"
|
|
cost = "Not a transaction block"
|
|
tx_filter_hash = "Not a transaction block"
|
|
fees = "Not a transaction block"
|
|
address_prefix = config["network_overrides"]["config"][config["selected_network"]]["address_prefix"]
|
|
farmer_address = encode_puzzle_hash(block.farmer_puzzle_hash, address_prefix)
|
|
pool_address = encode_puzzle_hash(block.pool_puzzle_hash, address_prefix)
|
|
pool_pk = (
|
|
full_block.reward_chain_block.proof_of_space.pool_public_key
|
|
if full_block.reward_chain_block.proof_of_space.pool_public_key is not None
|
|
else "Pay to pool puzzle hash"
|
|
)
|
|
print(
|
|
f"Block Height {block.height}\n"
|
|
f"Header Hash 0x{block.header_hash.hex()}\n"
|
|
f"Timestamp {block_time_string}\n"
|
|
f"Weight {block.weight}\n"
|
|
f"Previous Block 0x{block.prev_hash.hex()}\n"
|
|
f"Difficulty {difficulty}\n"
|
|
f"Sub-slot iters {block.sub_slot_iters}\n"
|
|
f"Cost {cost}\n"
|
|
f"Total VDF Iterations {block.total_iters}\n"
|
|
f"Is a Transaction Block?{block.is_transaction_block}\n"
|
|
f"Deficit {block.deficit}\n"
|
|
f"PoSpace 'k' Size {full_block.reward_chain_block.proof_of_space.size}\n"
|
|
f"Plot Public Key 0x{full_block.reward_chain_block.proof_of_space.plot_public_key}\n"
|
|
f"Pool Public Key {pool_pk}\n"
|
|
f"Tx Filter Hash {tx_filter_hash}\n"
|
|
f"Farmer Address {farmer_address}\n"
|
|
f"Pool Address {pool_address}\n"
|
|
f"Fees Amount {fees}\n"
|
|
)
|
|
else:
|
|
print("Block with header hash", block_header_hash_by_height, "not found")
|
|
|
|
except Exception as e:
|
|
if isinstance(e, aiohttp.ClientConnectorError):
|
|
print(f"Connection error. Check if full node rpc is running at {rpc_port}")
|
|
print("This is normal if full node is still starting up")
|
|
else:
|
|
tb = traceback.format_exc()
|
|
print(f"Exception from 'show' {tb}")
|
|
|
|
client.close()
|
|
await client.await_closed()
|
|
|
|
|
|
@click.command("show", short_help="Show node information")
|
|
@click.option(
|
|
"-p",
|
|
"--rpc-port",
|
|
help=(
|
|
"Set the port where the Full Node is hosting the RPC interface. "
|
|
"See the rpc_port under full_node in config.yaml"
|
|
),
|
|
type=int,
|
|
default=None,
|
|
)
|
|
@click.option(
|
|
"-wp",
|
|
"--wallet-rpc-port",
|
|
help="Set the port where the Wallet is hosting the RPC interface. See the rpc_port under wallet in config.yaml",
|
|
type=int,
|
|
default=None,
|
|
)
|
|
@click.option("-s", "--state", help="Show the current state of the blockchain", is_flag=True, type=bool, default=False)
|
|
@click.option(
|
|
"-c", "--connections", help="List nodes connected to this Full Node", is_flag=True, type=bool, default=False
|
|
)
|
|
@click.option("-e", "--exit-node", help="Shut down the running Full Node", is_flag=True, default=False)
|
|
@click.option("-a", "--add-connection", help="Connect to another Full Node by ip:port", type=str, default="")
|
|
@click.option(
|
|
"-r", "--remove-connection", help="Remove a Node by the first 8 characters of NodeID", type=str, default=""
|
|
)
|
|
@click.option(
|
|
"-bh", "--block-header-hash-by-height", help="Look up a block header hash by block height", type=str, default=""
|
|
)
|
|
@click.option("-b", "--block-by-header-hash", help="Look up a block by block header hash", type=str, default="")
|
|
def show_cmd(
|
|
rpc_port: int,
|
|
wallet_rpc_port: int,
|
|
state: bool,
|
|
connections: bool,
|
|
exit_node: bool,
|
|
add_connection: str,
|
|
remove_connection: str,
|
|
block_header_hash_by_height: str,
|
|
block_by_header_hash: str,
|
|
) -> None:
|
|
import asyncio
|
|
|
|
asyncio.run(
|
|
show_async(
|
|
rpc_port,
|
|
state,
|
|
connections,
|
|
exit_node,
|
|
add_connection,
|
|
remove_connection,
|
|
block_header_hash_by_height,
|
|
block_by_header_hash,
|
|
)
|
|
)
|