pub struct ExecutionRuntimeClient<T> { /* private fields */ }
Expand description
API:
Implementations§
source§impl<T> ExecutionRuntimeClient<T>where
T: GrpcService<BoxBody>,
T::Error: Into<StdError>,
T::ResponseBody: Body<Data = Bytes> + Send + 'static,
<T::ResponseBody as Body>::Error: Into<StdError> + Send,
impl<T> ExecutionRuntimeClient<T>where T: GrpcService<BoxBody>, T::Error: Into<StdError>, T::ResponseBody: Body<Data = Bytes> + Send + 'static, <T::ResponseBody as Body>::Error: Into<StdError> + Send,
pub fn new(inner: T) -> Self
pub fn with_origin(inner: T, origin: Uri) -> Self
pub fn with_interceptor<F>( inner: T, interceptor: F ) -> ExecutionRuntimeClient<InterceptedService<T, F>>where F: Interceptor, T::ResponseBody: Default, T: Service<Request<BoxBody>, Response = Response<<T as GrpcService<BoxBody>>::ResponseBody>>, <T as Service<Request<BoxBody>>>::Error: Into<StdError> + Send + Sync,
sourcepub fn send_compressed(self, encoding: CompressionEncoding) -> Self
pub fn send_compressed(self, encoding: CompressionEncoding) -> Self
Compress requests with the given encoding.
This requires the server to support it otherwise it might respond with an error.
sourcepub fn accept_compressed(self, encoding: CompressionEncoding) -> Self
pub fn accept_compressed(self, encoding: CompressionEncoding) -> Self
Enable decompressing responses.
sourcepub fn max_decoding_message_size(self, limit: usize) -> Self
pub fn max_decoding_message_size(self, limit: usize) -> Self
Limits the maximum size of a decoded message.
Default: 4MB
sourcepub fn max_encoding_message_size(self, limit: usize) -> Self
pub fn max_encoding_message_size(self, limit: usize) -> Self
Limits the maximum size of an encoded message.
Default: usize::MAX
pub async fn run_query( &mut self, request: impl IntoRequest<QueryAtFrame> ) -> Result<Response<QueryAtFrameResponse>, Status>
sourcepub async fn merge(
&mut self,
request: impl IntoRequest<RequestFileMerge>
) -> Result<Response<ExecutionStatus>, Status>
pub async fn merge( &mut self, request: impl IntoRequest<RequestFileMerge> ) -> Result<Response<ExecutionStatus>, Status>
- Merge a new file - if an existing file is available at the id, will merge the new file into the existing one
sourcepub async fn current_file_state(
&mut self,
request: impl IntoRequest<RequestOnlyId>
) -> Result<Response<File>, Status>
pub async fn current_file_state( &mut self, request: impl IntoRequest<RequestOnlyId> ) -> Result<Response<File>, Status>
- Get the current graph state of a file at a branch and counter position
sourcepub async fn get_parquet_history(
&mut self,
request: impl IntoRequest<RequestOnlyId>
) -> Result<Response<ParquetFile>, Status>
pub async fn get_parquet_history( &mut self, request: impl IntoRequest<RequestOnlyId> ) -> Result<Response<ParquetFile>, Status>
- Get the parquet history for a specific branch and Id - returns bytes
sourcepub async fn play(
&mut self,
request: impl IntoRequest<RequestAtFrame>
) -> Result<Response<ExecutionStatus>, Status>
pub async fn play( &mut self, request: impl IntoRequest<RequestAtFrame> ) -> Result<Response<ExecutionStatus>, Status>
- Resume execution
sourcepub async fn pause(
&mut self,
request: impl IntoRequest<RequestAtFrame>
) -> Result<Response<ExecutionStatus>, Status>
pub async fn pause( &mut self, request: impl IntoRequest<RequestAtFrame> ) -> Result<Response<ExecutionStatus>, Status>
- Pause execution
sourcepub async fn branch(
&mut self,
request: impl IntoRequest<RequestNewBranch>
) -> Result<Response<ExecutionStatus>, Status>
pub async fn branch( &mut self, request: impl IntoRequest<RequestNewBranch> ) -> Result<Response<ExecutionStatus>, Status>
- Split history into a separate branch
sourcepub async fn list_branches(
&mut self,
request: impl IntoRequest<RequestListBranches>
) -> Result<Response<ListBranchesRes>, Status>
pub async fn list_branches( &mut self, request: impl IntoRequest<RequestListBranches> ) -> Result<Response<ListBranchesRes>, Status>
- Get all branches
sourcepub async fn list_registered_graphs(
&mut self,
request: impl IntoRequest<Empty>
) -> Result<Response<Streaming<ExecutionStatus>>, Status>
pub async fn list_registered_graphs( &mut self, request: impl IntoRequest<Empty> ) -> Result<Response<Streaming<ExecutionStatus>>, Status>
- List all registered files
sourcepub async fn list_input_proposals(
&mut self,
request: impl IntoRequest<RequestOnlyId>
) -> Result<Response<Streaming<InputProposal>>, Status>
pub async fn list_input_proposals( &mut self, request: impl IntoRequest<RequestOnlyId> ) -> Result<Response<Streaming<InputProposal>>, Status>
- Receive a stream of input proposals <- this is a server-side stream
sourcepub async fn respond_to_input_proposal(
&mut self,
request: impl IntoRequest<RequestInputProposalResponse>
) -> Result<Response<Empty>, Status>
pub async fn respond_to_input_proposal( &mut self, request: impl IntoRequest<RequestInputProposalResponse> ) -> Result<Response<Empty>, Status>
- Push responses to input proposals (these wait for some input from a host until they’re resolved) <- RPC client to server
sourcepub async fn list_change_events(
&mut self,
request: impl IntoRequest<RequestOnlyId>
) -> Result<Response<Streaming<ChangeValueWithCounter>>, Status>
pub async fn list_change_events( &mut self, request: impl IntoRequest<RequestOnlyId> ) -> Result<Response<Streaming<ChangeValueWithCounter>>, Status>
- Observe the stream of execution events <- this is a server-side stream
pub async fn list_node_will_execute_events( &mut self, request: impl IntoRequest<RequestOnlyId> ) -> Result<Response<Streaming<NodeWillExecuteOnBranch>>, Status>
sourcepub async fn poll_custom_node_will_execute_events(
&mut self,
request: impl IntoRequest<FilteredPollNodeWillExecuteEventsRequest>
) -> Result<Response<RespondPollNodeWillExecuteEvents>, Status>
pub async fn poll_custom_node_will_execute_events( &mut self, request: impl IntoRequest<FilteredPollNodeWillExecuteEventsRequest> ) -> Result<Response<RespondPollNodeWillExecuteEvents>, Status>
- Observe when the server thinks our local node implementation should execute and with what changes
pub async fn ack_node_will_execute_event( &mut self, request: impl IntoRequest<RequestAckNodeWillExecuteEvent> ) -> Result<Response<ExecutionStatus>, Status>
sourcepub async fn push_worker_event(
&mut self,
request: impl IntoRequest<FileAddressedChangeValueWithCounter>
) -> Result<Response<ExecutionStatus>, Status>
pub async fn push_worker_event( &mut self, request: impl IntoRequest<FileAddressedChangeValueWithCounter> ) -> Result<Response<ExecutionStatus>, Status>
- Receive events from workers <- this is an RPC client to server, we don’t need to wait for a response from the server
pub async fn push_template_partial( &mut self, request: impl IntoRequest<UpsertPromptLibraryRecord> ) -> Result<Response<ExecutionStatus>, Status>
Trait Implementations§
source§impl<T: Clone> Clone for ExecutionRuntimeClient<T>
impl<T: Clone> Clone for ExecutionRuntimeClient<T>
source§fn clone(&self) -> ExecutionRuntimeClient<T>
fn clone(&self) -> ExecutionRuntimeClient<T>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreAuto Trait Implementations§
impl<T> RefUnwindSafe for ExecutionRuntimeClient<T>where T: RefUnwindSafe,
impl<T> Send for ExecutionRuntimeClient<T>where T: Send,
impl<T> Sync for ExecutionRuntimeClient<T>where T: Sync,
impl<T> Unpin for ExecutionRuntimeClient<T>where T: Unpin,
impl<T> UnwindSafe for ExecutionRuntimeClient<T>where T: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request