pub async fn controller_service<NC, PG>(
nats_client: &NatsClient,
node_client: &NC,
piece_getter: &PG,
farmer_caches: &[(&str, &FarmerCache)],
instance: &str,
primary_instance: bool,
) -> Result<()>where
NC: NodeClient,
PG: PieceGetter + Sync,
Expand description
Create controller service that handles things like broadcasting information (for example slot notifications) as well as responding to incoming requests (like piece requests).
Implementation is using concurrency with multiple tokio tasks, but can be started multiple times per controller instance in order to parallelize more work across threads if needed.