pub struct StatementExecutor {
    catalog_manager: CatalogManagerRef,
    query_engine: QueryEngineRef,
    procedure_executor: ProcedureExecutorRef,
    table_metadata_manager: TableMetadataManagerRef,
    flow_metadata_manager: FlowMetadataManagerRef,
    view_info_manager: ViewInfoManagerRef,
    partition_manager: PartitionRuleManagerRef,
    cache_invalidator: CacheInvalidatorRef,
    inserter: InserterRef,
    process_manager: Option<ProcessManagerRef>,
}Fields§
§catalog_manager: CatalogManagerRef§query_engine: QueryEngineRef§procedure_executor: ProcedureExecutorRef§table_metadata_manager: TableMetadataManagerRef§flow_metadata_manager: FlowMetadataManagerRef§view_info_manager: ViewInfoManagerRef§partition_manager: PartitionRuleManagerRef§cache_invalidator: CacheInvalidatorRef§inserter: InserterRef§process_manager: Option<ProcessManagerRef>Implementations§
Source§impl StatementExecutor
 
impl StatementExecutor
Sourcepub(super) async fn execute_admin_command(
    &self,
    stmt: Admin,
    query_ctx: QueryContextRef,
) -> Result<Output>
 
pub(super) async fn execute_admin_command( &self, stmt: Admin, query_ctx: QueryContextRef, ) -> Result<Output>
Execute the Admin statement and returns the output.
Source§impl StatementExecutor
 
impl StatementExecutor
pub(crate) async fn copy_database_to( &self, req: CopyDatabaseRequest, ctx: QueryContextRef, ) -> Result<Output>
Sourcepub(crate) async fn copy_database_from(
    &self,
    req: CopyDatabaseRequest,
    ctx: QueryContextRef,
) -> Result<Output>
 
pub(crate) async fn copy_database_from( &self, req: CopyDatabaseRequest, ctx: QueryContextRef, ) -> Result<Output>
Imports data to database from a given location and returns total rows imported.
Source§impl StatementExecutor
 
impl StatementExecutor
pub(crate) async fn copy_query_to( &self, req: CopyQueryToRequest, query_output: Output, ) -> Result<usize>
Source§impl StatementExecutor
 
impl StatementExecutor
async fn list_copy_from_entries( &self, req: &CopyTableRequest, ) -> Result<(ObjectStore, Vec<Entry>)>
async fn collect_metadata( &self, object_store: &ObjectStore, format: Format, path: String, ) -> Result<FileMetadata>
async fn build_file_stream( &self, store: &ObjectStore, filename: &str, file_schema: SchemaRef, file_source: Arc<dyn FileSource>, projection: Option<Vec<usize>>, ) -> Result<DfSendableRecordBatchStream>
async fn build_read_stream( &self, compat_schema: SchemaRef, object_store: &ObjectStore, file_metadata: &FileMetadata, projection: Vec<usize>, filters: Vec<Expr>, ) -> Result<DfSendableRecordBatchStream>
pub async fn copy_table_from( &self, req: CopyTableRequest, query_ctx: QueryContextRef, ) -> Result<Output>
Source§impl StatementExecutor
 
impl StatementExecutor
async fn stream_to_file( &self, stream: SendableRecordBatchStream, format: &Format, object_store: ObjectStore, path: &str, ) -> Result<usize>
pub(crate) async fn copy_table_to( &self, req: CopyTableRequest, query_ctx: QueryContextRef, ) -> Result<usize>
pub(crate) async fn copy_to_file( &self, format: &Format, output: Output, location: &str, connection: &HashMap<String, String>, ) -> Result<usize>
Source§impl StatementExecutor
 
impl StatementExecutor
pub(super) async fn declare_cursor( &self, declare_cursor: DeclareCursor, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn fetch_cursor( &self, fetch_cursor: FetchCursor, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn close_cursor( &self, close_cursor: CloseCursor, query_ctx: QueryContextRef, ) -> Result<Output>
Source§impl StatementExecutor
 
impl StatementExecutor
pub fn catalog_manager(&self) -> CatalogManagerRef
pub async fn create_table( &self, stmt: CreateTable, ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn create_table_like( &self, stmt: CreateTableLike, ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn create_external_table( &self, create_expr: CreateExternalTable, ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn create_table_inner( &self, create_table: &mut CreateTableExpr, partitions: Option<Partitions>, query_ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn create_non_logic_table( &self, create_table: &mut CreateTableExpr, partitions: Option<Partitions>, query_ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn create_logical_tables( &self, create_table_exprs: &[CreateTableExpr], query_context: QueryContextRef, ) -> Result<Vec<TableRef>>
pub async fn create_flow( &self, stmt: CreateFlow, query_context: QueryContextRef, ) -> Result<Output>
pub async fn create_flow_inner( &self, expr: CreateFlowExpr, query_context: QueryContextRef, ) -> Result<Output>
async fn create_flow_procedure( &self, expr: CreateFlowExpr, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
Sourceasync fn determine_flow_type(
    &self,
    expr: &CreateFlowExpr,
    query_ctx: QueryContextRef,
) -> Result<FlowType>
 
async fn determine_flow_type( &self, expr: &CreateFlowExpr, query_ctx: QueryContextRef, ) -> Result<FlowType>
Determine the flow type based on the SQL query
If it contains aggregation or distinct, then it is a batch flow, otherwise it is a streaming flow
pub async fn create_view( &self, create_view: CreateView, ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn create_view_by_expr( &self, expr: CreateViewExpr, ctx: QueryContextRef, ) -> Result<TableRef>
pub async fn drop_flow( &self, catalog_name: String, flow_name: String, drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<Output>
async fn drop_flow_procedure( &self, expr: DropFlowTask, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
Sourcepub(crate) async fn drop_view(
    &self,
    catalog: String,
    schema: String,
    view: String,
    drop_if_exists: bool,
    query_context: QueryContextRef,
) -> Result<Output>
 
pub(crate) async fn drop_view( &self, catalog: String, schema: String, view: String, drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<Output>
Drop a view
Sourceasync fn drop_view_procedure(
    &self,
    expr: DropViewTask,
    query_context: QueryContextRef,
) -> Result<SubmitDdlTaskResponse>
 
async fn drop_view_procedure( &self, expr: DropViewTask, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
Submit DropViewTask to procedure executor.
pub async fn alter_logical_tables( &self, alter_table_exprs: Vec<AlterTableExpr>, query_context: QueryContextRef, ) -> Result<Output>
pub async fn drop_table( &self, table_name: TableName, drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<Output>
pub async fn drop_tables( &self, table_names: &[TableName], drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<Output>
pub async fn drop_database( &self, catalog: String, schema: String, drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<Output>
pub async fn truncate_table( &self, table_name: TableName, time_ranges: Vec<(Timestamp, Timestamp)>, query_context: QueryContextRef, ) -> Result<Output>
pub async fn alter_table( &self, alter_table: AlterTable, query_context: QueryContextRef, ) -> Result<Output>
pub async fn alter_table_inner( &self, expr: AlterTableExpr, query_context: QueryContextRef, ) -> Result<Output>
pub async fn alter_database( &self, alter_expr: AlterDatabase, query_context: QueryContextRef, ) -> Result<Output>
pub async fn alter_database_inner( &self, alter_expr: AlterDatabaseExpr, query_context: QueryContextRef, ) -> Result<Output>
async fn create_table_procedure( &self, create_table: CreateTableExpr, partitions: Vec<PartitionExpr>, table_info: RawTableInfo, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
async fn create_logical_tables_procedure( &self, tables_data: Vec<(CreateTableExpr, RawTableInfo)>, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
async fn alter_logical_tables_procedure( &self, tables_data: Vec<AlterTableExpr>, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
async fn drop_table_procedure( &self, table_name: &TableName, table_id: TableId, drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
async fn drop_database_procedure( &self, catalog: String, schema: String, drop_if_exists: bool, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
async fn alter_database_procedure( &self, alter_expr: AlterDatabaseExpr, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
async fn truncate_table_procedure( &self, table_name: &TableName, table_id: TableId, time_ranges: Vec<(Timestamp, Timestamp)>, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
pub async fn create_database( &self, database: &str, create_if_not_exists: bool, options: HashMap<String, String>, query_context: QueryContextRef, ) -> Result<Output>
async fn create_database_procedure( &self, catalog: String, database: String, create_if_not_exists: bool, options: HashMap<String, String>, query_context: QueryContextRef, ) -> Result<SubmitDdlTaskResponse>
Source§impl StatementExecutor
 
impl StatementExecutor
pub(super) async fn describe_table( &self, stmt: DescribeTable, query_ctx: QueryContextRef, ) -> Result<Output>
Source§impl StatementExecutor
 
impl StatementExecutor
pub async fn execute_kill( &self, query_ctx: QueryContextRef, kill: Kill, ) -> Result<Output>
Sourceasync fn kill_process_id(
    &self,
    pm: &ProcessManagerRef,
    query_ctx: QueryContextRef,
    process_id: String,
) -> Result<bool>
 
async fn kill_process_id( &self, pm: &ProcessManagerRef, query_ctx: QueryContextRef, process_id: String, ) -> Result<bool>
Handles KILL <PROCESS_ID> statements.
Sourcepub async fn kill_connection_id(
    &self,
    pm: &ProcessManagerRef,
    query_ctx: QueryContextRef,
    connection_id: u32,
) -> Result<bool>
 
pub async fn kill_connection_id( &self, pm: &ProcessManagerRef, query_ctx: QueryContextRef, connection_id: u32, ) -> Result<bool>
Handles MySQL KILL QUERY <CONNECTION_ID> statements.
Source§impl StatementExecutor
 
impl StatementExecutor
pub(super) async fn show_databases( &self, stmt: ShowDatabases, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_tables( &self, stmt: ShowTables, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_table_status( &self, stmt: ShowTableStatus, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_columns( &self, stmt: ShowColumns, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_index( &self, stmt: ShowIndex, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_region( &self, stmt: ShowRegion, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_create_database( &self, database_name: &str, opts: OptionMap, ) -> Result<Output>
pub async fn show_create_table( &self, table_name: TableName, table: TableRef, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_create_table_for_pg( &self, table_name: TableName, table: TableRef, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_create_view( &self, show: ShowCreateView, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_views( &self, stmt: ShowViews, query_ctx: QueryContextRef, ) -> Result<Output>
pub(super) async fn show_flows( &self, stmt: ShowFlows, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_create_flow( &self, show: ShowCreateFlow, query_ctx: QueryContextRef, ) -> Result<Output>
pub fn show_variable( &self, stmt: ShowVariables, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_collation( &self, kind: ShowKind, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_charset( &self, kind: ShowKind, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_status(&self, query_ctx: QueryContextRef) -> Result<Output>
pub async fn show_search_path( &self, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn show_processlist( &self, stmt: ShowProcessList, query_ctx: QueryContextRef, ) -> Result<Output>
Source§impl StatementExecutor
 
impl StatementExecutor
Sourcepub async fn plan_tql(
    &self,
    tql: Tql,
    query_ctx: &QueryContextRef,
) -> Result<LogicalPlan>
 
pub async fn plan_tql( &self, tql: Tql, query_ctx: &QueryContextRef, ) -> Result<LogicalPlan>
Plan the given Tql query and return the [LogicalPlan].
Sourcepub(super) async fn execute_tql(
    &self,
    tql: Tql,
    query_ctx: QueryContextRef,
) -> Result<Output>
 
pub(super) async fn execute_tql( &self, tql: Tql, query_ctx: QueryContextRef, ) -> Result<Output>
Execute the given Tql query and return the result.
Source§impl StatementExecutor
 
impl StatementExecutor
pub fn new( catalog_manager: CatalogManagerRef, query_engine: QueryEngineRef, procedure_executor: ProcedureExecutorRef, kv_backend: KvBackendRef, cache_invalidator: CacheInvalidatorRef, inserter: InserterRef, table_route_cache: TableRouteCacheRef, process_manager: Option<ProcessManagerRef>, ) -> Self
pub async fn execute_stmt( &self, stmt: QueryStatement, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn execute_sql( &self, stmt: Statement, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn use_database( &self, db: String, query_ctx: QueryContextRef, ) -> Result<Output>
fn set_variables( &self, set_var: SetVariables, query_ctx: QueryContextRef, ) -> Result<Output>
pub async fn plan( &self, stmt: &QueryStatement, query_ctx: QueryContextRef, ) -> Result<LogicalPlan>
Sourcepub async fn exec_plan(
    &self,
    plan: LogicalPlan,
    query_ctx: QueryContextRef,
) -> Result<Output>
 
pub async fn exec_plan( &self, plan: LogicalPlan, query_ctx: QueryContextRef, ) -> Result<Output>
Execute [LogicalPlan] directly.
pub fn optimize_logical_plan(&self, plan: LogicalPlan) -> Result<LogicalPlan>
async fn plan_exec( &self, stmt: QueryStatement, query_ctx: QueryContextRef, ) -> Result<Output>
async fn get_table(&self, table_ref: &TableReference<'_>) -> Result<TableRef>
pub fn procedure_executor(&self) -> &ProcedureExecutorRef
pub fn cache_invalidator(&self) -> &CacheInvalidatorRef
Sourcepub async fn convert_truncate_time_ranges(
    &self,
    table_name: &TableName,
    sql_values_time_range: &[(Value, Value)],
    query_ctx: &QueryContextRef,
) -> Result<Vec<(Timestamp, Timestamp)>>
 
pub async fn convert_truncate_time_ranges( &self, table_name: &TableName, sql_values_time_range: &[(Value, Value)], query_ctx: &QueryContextRef, ) -> Result<Vec<(Timestamp, Timestamp)>>
Convert truncate time ranges for the given table from sql values to timestamps
Sourcepub(crate) fn inserter(&self) -> &InserterRef
 
pub(crate) fn inserter(&self) -> &InserterRef
Returns the inserter for the statement executor.
Trait Implementations§
Source§impl Clone for StatementExecutor
 
impl Clone for StatementExecutor
Source§fn clone(&self) -> StatementExecutor
 
fn clone(&self) -> StatementExecutor
Returns a duplicate 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 Freeze for StatementExecutor
impl !RefUnwindSafe for StatementExecutor
impl Send for StatementExecutor
impl Sync for StatementExecutor
impl Unpin for StatementExecutor
impl !UnwindSafe for StatementExecutor
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> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
§impl<T> Conv for T
 
impl<T> Conv for T
§impl<T, V> Convert<T> for Vwhere
    V: Into<T>,
 
impl<T, V> Convert<T> for Vwhere
    V: Into<T>,
fn convert(value: Self) -> T
fn convert_box(value: Box<Self>) -> Box<T>
fn convert_vec(value: Vec<Self>) -> Vec<T>
fn convert_vec_box(value: Vec<Box<Self>>) -> Vec<Box<T>>
fn convert_matrix(value: Vec<Vec<Self>>) -> Vec<Vec<T>>
fn convert_option(value: Option<Self>) -> Option<T>
fn convert_option_box(value: Option<Box<Self>>) -> Option<Box<T>>
fn convert_option_vec(value: Option<Vec<Self>>) -> Option<Vec<T>>
§impl<T> FmtForward for T
 
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
 
fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
Causes 
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
 
fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
Causes 
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
 
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
Causes 
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
 
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
Causes 
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
 
fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
Causes 
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
 
fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
Causes 
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
 
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
Causes 
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
 
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
Causes 
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
    &'a Self: for<'a> IntoIterator,
 
fn fmt_list(self) -> FmtList<Self>where
    &'a Self: for<'a> IntoIterator,
Formats each item in a sequence. Read more
§impl<T> FutureExt for T
 
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
 
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
 
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
 
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts 
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts 
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> IntoRequest<T> for T
 
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
 
fn into_request(self) -> Request<T>
Wrap the input message 
T in a tonic::Request§impl<L> LayerExt<L> for L
 
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
    L: Layer<S>,
 
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
    L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].§impl<T> Pipe for Twhere
    T: ?Sized,
 
impl<T> Pipe for Twhere
    T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
 
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
Borrows 
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
Mutably borrows 
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
 
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
    &'a mut self,
    func: impl FnOnce(&'a mut B) -> R,
) -> R
 
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
 
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows 
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
 
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows 
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
 
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows 
self, then passes self.deref() into the pipe function.§impl<T> Pointable for T
 
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
    T: ?Sized,
 
impl<T> PolicyExt for Twhere
    T: ?Sized,
§impl<T> ServiceExt for T
 
impl<T> ServiceExt for T
§fn propagate_header(self, header: HeaderName) -> PropagateHeader<Self>where
    Self: Sized,
 
fn propagate_header(self, header: HeaderName) -> PropagateHeader<Self>where
    Self: Sized,
Propagate a header from the request to the response. Read more
§fn add_extension<T>(self, value: T) -> AddExtension<Self, T>where
    Self: Sized,
 
fn add_extension<T>(self, value: T) -> AddExtension<Self, T>where
    Self: Sized,
Add some shareable value to request extensions. Read more
§fn map_request_body<F>(self, f: F) -> MapRequestBody<Self, F>where
    Self: Sized,
 
fn map_request_body<F>(self, f: F) -> MapRequestBody<Self, F>where
    Self: Sized,
Apply a transformation to the request body. Read more
§fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
    Self: Sized,
 
fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
    Self: Sized,
Apply a transformation to the response body. Read more
§fn compression(self) -> Compression<Self>where
    Self: Sized,
 
fn compression(self) -> Compression<Self>where
    Self: Sized,
Compresses response bodies. Read more
§fn decompression(self) -> Decompression<Self>where
    Self: Sized,
 
fn decompression(self) -> Decompression<Self>where
    Self: Sized,
Decompress response bodies. Read more
§fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
    Self: Sized,
 
fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
    Self: Sized,
High level tracing that classifies responses using HTTP status codes. Read more
§fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
    Self: Sized,
 
fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
    Self: Sized,
High level tracing that classifies responses using gRPC headers. Read more
§fn follow_redirects(self) -> FollowRedirect<Self>where
    Self: Sized,
 
fn follow_redirects(self) -> FollowRedirect<Self>where
    Self: Sized,
§fn sensitive_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<SetSensitiveResponseHeaders<Self>>where
    Self: Sized,
 
fn sensitive_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<SetSensitiveResponseHeaders<Self>>where
    Self: Sized,
§fn sensitive_request_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<Self>where
    Self: Sized,
 
fn sensitive_request_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<Self>where
    Self: Sized,
§fn sensitive_response_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveResponseHeaders<Self>where
    Self: Sized,
 
fn sensitive_response_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveResponseHeaders<Self>where
    Self: Sized,
§fn override_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
 
fn override_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
Insert a header into the request. Read more
§fn append_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
 
fn append_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
Append a header into the request. Read more
§fn insert_request_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
 
fn insert_request_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
Insert a header into the request, if the header is not already present. Read more
§fn override_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
 
fn override_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
Insert a header into the response. Read more
§fn append_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
 
fn append_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
Append a header into the response. Read more
§fn insert_response_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
 
fn insert_response_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
Insert a header into the response, if the header is not already present. Read more
§fn set_request_id<M>(
    self,
    header_name: HeaderName,
    make_request_id: M,
) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
 
fn set_request_id<M>(
    self,
    header_name: HeaderName,
    make_request_id: M,
) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
Add request id header and extension. Read more
§fn set_x_request_id<M>(self, make_request_id: M) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
 
fn set_x_request_id<M>(self, make_request_id: M) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
Add request id header and extension, using 
x-request-id as the header name. Read more§fn propagate_request_id(
    self,
    header_name: HeaderName,
) -> PropagateRequestId<Self>where
    Self: Sized,
 
fn propagate_request_id(
    self,
    header_name: HeaderName,
) -> PropagateRequestId<Self>where
    Self: Sized,
Propgate request ids from requests to responses. Read more
§fn propagate_x_request_id(self) -> PropagateRequestId<Self>where
    Self: Sized,
 
fn propagate_x_request_id(self) -> PropagateRequestId<Self>where
    Self: Sized,
Propgate request ids from requests to responses, using 
x-request-id as the header name. Read more§fn catch_panic(self) -> CatchPanic<Self, DefaultResponseForPanic>where
    Self: Sized,
 
fn catch_panic(self) -> CatchPanic<Self, DefaultResponseForPanic>where
    Self: Sized,
Catch panics and convert them into 
500 Internal Server responses. Read more§fn request_body_limit(self, limit: usize) -> RequestBodyLimit<Self>where
    Self: Sized,
 
fn request_body_limit(self, limit: usize) -> RequestBodyLimit<Self>where
    Self: Sized,
Intercept requests with over-sized payloads and convert them into
413 Payload Too Large responses. Read more§fn trim_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
 
fn trim_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
Remove trailing slashes from paths. Read more
§fn append_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
 
fn append_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
Append trailing slash to paths. Read more
§impl<SS, SP> SupersetOf<SS> for SPwhere
    SS: SubsetOf<SP>,
 
impl<SS, SP> SupersetOf<SS> for SPwhere
    SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
 
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct 
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
 
fn is_in_subset(&self) -> bool
Checks if 
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
 
fn to_subset_unchecked(&self) -> SS
Use with care! Same as 
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
 
fn from_subset(element: &SS) -> SP
The inclusion map: converts 
self to the equivalent element of its superset.§impl<T> Tap for T
 
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
 
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the 
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
 
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the 
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
 
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the 
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
 
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the 
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
 
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the 
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
 
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the 
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
 
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls 
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
 
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls 
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
 
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls 
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
 
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls 
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
 
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls 
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
 
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls 
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
 
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls 
.tap_deref() only in debug builds, and is erased in release
builds.