chia-blockchain/chia/server/start_data_layer.py
Kyle Altendorf 3b084a165b
configure isort to add the future annotations import (#13327)
* configure isort to add the future annotations import

* apply the new isort setting

* remove type ignores for new mypy (#13539)

https://pypi.org/project/mypy/0.981/

* another
2022-09-30 03:40:22 -05:00

102 lines
3.4 KiB
Python

from __future__ import annotations
import logging
import pathlib
import sys
from typing import Any, Dict, Optional, cast
from chia.cmds.init_funcs import create_all_ssl
from chia.data_layer.data_layer import DataLayer
from chia.data_layer.data_layer_api import DataLayerAPI
from chia.rpc.data_layer_rpc_api import DataLayerRpcApi
from chia.rpc.wallet_rpc_client import WalletRpcClient
from chia.server.outbound_message import NodeType
from chia.server.start_service import RpcInfo, Service, async_run
from chia.server.start_wallet import WalletNode
from chia.util.chia_logging import initialize_logging
from chia.util.config import load_config, load_config_cli
from chia.util.default_root import DEFAULT_ROOT_PATH
from chia.util.ints import uint16
# See: https://bugs.python.org/issue29288
"".encode("idna")
SERVICE_NAME = "data_layer"
log = logging.getLogger(__name__)
# TODO: Review need for config and if retained then hint it properly.
def create_data_layer_service(
root_path: pathlib.Path,
config: Dict[str, Any],
wallet_service: Optional[Service[WalletNode]] = None,
connect_to_daemon: bool = True,
) -> Service[DataLayer]:
service_config = config[SERVICE_NAME]
self_hostname = config["self_hostname"]
wallet_rpc_port = service_config["wallet_peer"]["port"]
if wallet_service is None:
wallet_root_path = root_path
wallet_config = config
else:
wallet_root_path = wallet_service.root_path
wallet_config = wallet_service.config
wallet_rpc_init = WalletRpcClient.create(self_hostname, uint16(wallet_rpc_port), wallet_root_path, wallet_config)
data_layer = DataLayer(config=service_config, root_path=root_path, wallet_rpc_init=wallet_rpc_init)
api = DataLayerAPI(data_layer)
network_id = service_config["selected_network"]
rpc_port = service_config.get("rpc_port")
rpc_info: Optional[RpcInfo] = None
if rpc_port is not None:
rpc_info = (DataLayerRpcApi, cast(int, service_config["rpc_port"]))
return Service(
server_listen_ports=[service_config["port"]],
root_path=root_path,
config=config,
node=data_layer,
# TODO: not for peers...
peer_api=api,
node_type=NodeType.DATA_LAYER,
# TODO: no publicly advertised port, at least not yet
advertised_port=service_config["port"],
service_name=SERVICE_NAME,
network_id=network_id,
max_request_body_size=service_config.get("rpc_server_max_request_body_size", 26214400),
rpc_info=rpc_info,
connect_to_daemon=connect_to_daemon,
)
async def async_main() -> int:
# TODO: refactor to avoid the double load
config = load_config(DEFAULT_ROOT_PATH, "config.yaml", fill_missing_services=True)
service_config = load_config_cli(DEFAULT_ROOT_PATH, "config.yaml", SERVICE_NAME, fill_missing_services=True)
config[SERVICE_NAME] = service_config
initialize_logging(
service_name=SERVICE_NAME,
logging_config=service_config["logging"],
root_path=DEFAULT_ROOT_PATH,
)
create_all_ssl(
root_path=DEFAULT_ROOT_PATH,
private_node_names=["data_layer"],
public_node_names=["data_layer"],
overwrite=False,
)
service = create_data_layer_service(DEFAULT_ROOT_PATH, config)
await service.setup_process_global_state()
await service.run()
return 0
def main() -> int:
return async_run(async_main())
if __name__ == "__main__":
sys.exit(main())