pub mod pb { tonic::include_proto!("grpc.examples.echo"); } use futures::Stream; use pb::{EchoRequest, EchoResponse}; use std::pin::Pin; use tonic::transport::{Certificate, Identity, Server, ServerTlsConfig}; use tonic::{Request, Response, Status}; type EchoResult = Result, Status>; type ResponseStream = Pin> + Send + Sync>>; #[derive(Default)] pub struct EchoServer; #[tonic::async_trait] impl pb::echo_server::Echo for EchoServer { async fn unary_echo(&self, request: Request) -> EchoResult { let certs = request .peer_certs() .expect("Client did not send its certs!"); println!("Got {} peer certs!", certs.len()); let message = request.into_inner().message; Ok(Response::new(EchoResponse { message })) } type ServerStreamingEchoStream = ResponseStream; async fn server_streaming_echo( &self, _: Request, ) -> Result, Status> { Err(Status::unimplemented("Not yet implemented")) } async fn client_streaming_echo( &self, _: Request>, ) -> Result, Status> { Err(Status::unimplemented("Not yet implemented")) } type BidirectionalStreamingEchoStream = ResponseStream; async fn bidirectional_streaming_echo( &self, _: Request>, ) -> Result, Status> { Err(Status::unimplemented("Not yet implemented")) } } #[tokio::main] async fn main() -> Result<(), Box> { let cert = tokio::fs::read("examples/data/tls/server.pem").await?; let key = tokio::fs::read("examples/data/tls/server.key").await?; let server_identity = Identity::from_pem(cert, key); let client_ca_cert = tokio::fs::read("examples/data/tls/client_ca.pem").await?; let client_ca_cert = Certificate::from_pem(client_ca_cert); let addr = "[::1]:50051".parse().unwrap(); let server = EchoServer::default(); let tls = ServerTlsConfig::new() .identity(server_identity) .client_ca_root(client_ca_cert); Server::builder() .tls_config(tls)? .add_service(pb::echo_server::EchoServer::new(server)) .serve(addr) .await?; Ok(()) }