servers/query_handler/
grpc.rs1use std::pin::Pin;
16use std::sync::Arc;
17
18use api::v1::greptime_request::Request;
19use async_trait::async_trait;
20use common_grpc::flight::do_put::DoPutResponse;
21use common_query::Output;
22use futures::Stream;
23use session::context::QueryContextRef;
24
25use crate::error::Result;
26use crate::grpc::flight::PutRecordBatchRequestStream;
27
28pub type ServerGrpcQueryHandlerRef = Arc<dyn GrpcQueryHandler + Send + Sync>;
29
30pub type RawRecordBatch = bytes::Bytes;
31
32#[async_trait]
33pub trait GrpcQueryHandler {
34 async fn do_query(&self, query: Request, ctx: QueryContextRef) -> Result<Output>;
35
36 fn handle_put_record_batch_stream(
37 &self,
38 stream: PutRecordBatchRequestStream,
39 ctx: QueryContextRef,
40 ) -> Pin<Box<dyn Stream<Item = Result<DoPutResponse>> + Send>>;
41}