use futures::Future; use grpcio::{RpcContext, UnarySink}; use protos::services::{ BeaconBlock as BeaconBlockProto, ProduceBeaconBlockRequest, ProduceBeaconBlockResponse, PublishBeaconBlockRequest, PublishBeaconBlockResponse, }; use protos::services_grpc::BeaconBlockService; use slog::Logger; #[derive(Clone)] pub struct BeaconBlockServiceInstance { network_chan: crossbeam_channel::Sender, pub log: Logger, } impl BeaconBlockService for BeaconBlockServiceInstance { /// Produce a `BeaconBlock` for signing by a validator. fn produce_beacon_block( &mut self, ctx: RpcContext, req: ProduceBeaconBlockRequest, sink: UnarySink, ) { println!("producing at slot {}", req.get_slot()); // TODO: build a legit block. let mut block = BeaconBlockProto::new(); block.set_slot(req.get_slot()); block.set_block_root(b"cats".to_vec()); let mut resp = ProduceBeaconBlockResponse::new(); resp.set_block(block); let f = sink .success(resp) .map_err(move |e| println!("failed to reply {:?}: {:?}", req, e)); ctx.spawn(f) } /// Accept some fully-formed `BeaconBlock`, process and publish it. fn publish_beacon_block( &mut self, ctx: RpcContext, req: PublishBeaconBlockRequest, sink: UnarySink, ) { let block = req.get_block(); println!("publishing {:?}", block); // TODO: Build properly let topic = types::TopicBuilder:: println!("Sending beacon block to gossipsub"); network_chan.send(NetworkMessage::Publish( // TODO: actually process the block. let mut resp = PublishBeaconBlockResponse::new(); resp.set_success(true); let f = sink .success(resp) .map_err(move |e| println!("failed to reply {:?}: {:?}", req, e)); ctx.spawn(f) } }