mirror of
https://github.com/Chia-Network/chia-blockchain.git
synced 2024-09-21 08:31:52 +03:00
5e4c1a1f62
* Add mempool_max_total_cost to RPC * Add signage_point event * Fix incorrect crawler RPC port lookup * Set up initial timelord RPC server + finished_pot_challenge event * Add new compact proof event * Add skipping/new_peak to track when fastest or not * Check for None on change_data * Add skipping_peak + new_peak to changes for metrics * Convert chain to value * Rename iters * Timelord RPC to 8557 - 8556 is used in simulation tests * Make tests work with RPC server on timelord * Change event name to finished_pot * Use broadcast_farmer object * Move state changed for `finished_pot` after proofs_finished.append * Fix type on ips var + add vdf_info and vdf_proof * fix event name on the state_changed function
65 lines
1.9 KiB
Python
65 lines
1.9 KiB
Python
import logging
|
|
import pathlib
|
|
from typing import Dict
|
|
|
|
from chia.consensus.constants import ConsensusConstants
|
|
from chia.consensus.default_constants import DEFAULT_CONSTANTS
|
|
from chia.rpc.timelord_rpc_api import TimelordRpcApi
|
|
from chia.server.outbound_message import NodeType
|
|
from chia.server.start_service import run_service
|
|
from chia.timelord.timelord import Timelord
|
|
from chia.timelord.timelord_api import TimelordAPI
|
|
from chia.types.peer_info import PeerInfo
|
|
from chia.util.config import load_config_cli
|
|
from chia.util.default_root import DEFAULT_ROOT_PATH
|
|
|
|
# See: https://bugs.python.org/issue29288
|
|
"".encode("idna")
|
|
|
|
SERVICE_NAME = "timelord"
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
def service_kwargs_for_timelord(
|
|
root_path: pathlib.Path,
|
|
config: Dict,
|
|
constants: ConsensusConstants,
|
|
) -> Dict:
|
|
|
|
connect_peers = [PeerInfo(config["full_node_peer"]["host"], config["full_node_peer"]["port"])]
|
|
overrides = config["network_overrides"]["constants"][config["selected_network"]]
|
|
updated_constants = constants.replace_str_to_bytes(**overrides)
|
|
|
|
node = Timelord(root_path, config, updated_constants)
|
|
peer_api = TimelordAPI(node)
|
|
network_id = config["selected_network"]
|
|
kwargs = dict(
|
|
root_path=root_path,
|
|
peer_api=peer_api,
|
|
node=node,
|
|
node_type=NodeType.TIMELORD,
|
|
advertised_port=config["port"],
|
|
service_name=SERVICE_NAME,
|
|
server_listen_ports=[config["port"]],
|
|
connect_peers=connect_peers,
|
|
auth_connect_peers=False,
|
|
network_id=network_id,
|
|
)
|
|
|
|
if config.get("start_rpc_server", True):
|
|
kwargs["rpc_info"] = (TimelordRpcApi, config.get("rpc_port", 8557))
|
|
|
|
return kwargs
|
|
|
|
|
|
def main() -> None:
|
|
config = load_config_cli(DEFAULT_ROOT_PATH, "config.yaml", SERVICE_NAME)
|
|
kwargs = service_kwargs_for_timelord(DEFAULT_ROOT_PATH, config, DEFAULT_CONSTANTS)
|
|
return run_service(**kwargs)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|