#include <userver/ugrpc/server/rpc.hpp>
Controls a single request -> response stream RPC.
This class is not thread-safe except for GetContext
.
The RPC is cancelled on destruction unless the stream has been finished.
If any method throws, further methods must not be called on the same stream, except for GetContext
.
Public Member Functions | |
void | Write (Response &response) override |
Write the next outgoing message. | |
void | Write (Response &&response) override |
Write the next outgoing message. | |
void | Finish () |
Complete the RPC successfully. | |
void | FinishWithError (const grpc::Status &status) override |
Complete the RPC with an error. | |
void | WriteAndFinish (Response &response) |
Equivalent to Write + Finish | |
void | WriteAndFinish (Response &&response) |
Equivalent to Write + Finish | |
OutputStream (impl::CallParams &&call_params, impl::RawWriter< Response > &stream) | |
For internal use only. | |
OutputStream (OutputStream &&)=delete | |
OutputStream & | operator= (OutputStream &&)=delete |
bool | IsFinished () const override |
Useful for generic error reporting via FinishWithError. | |
grpc::ServerContext & | GetContext () |
std::string_view | GetCallName () const |
Name of the RPC in the format full.path.ServiceName/MethodName | |
std::string_view | GetServiceName () const |
Get name of gRPC service. | |
std::string_view | GetMethodName () const |
Get name of called gRPC method. | |
tracing::Span & | GetSpan () |
Get the span of the current RPC. Span's lifetime covers the Handle call of the outermost middleware. | |
CallKind | GetCallKind () const |
Get RPCs kind of method. | |
utils::AnyStorage< StorageContext > & | GetStorageContext () |
Returns call context for storing per-call custom data. | |
void | SetMetricsCallName (std::string_view call_name) |
Set a custom call name for metric labels. | |
Protected Member Functions | |
ugrpc::impl::RpcStatisticsScope & | GetStatistics () |
logging::LoggerRef | AccessTskvLogger () |
void | LogFinish (grpc::Status status) const |
void | ApplyRequestHook (google::protobuf::Message *request) |
void | ApplyResponseHook (google::protobuf::Message *response) |
ugrpc::server::OutputStream< Response >::OutputStream | ( | impl::CallParams && | call_params, |
impl::RawWriter< Response > & | stream ) |
|
override |
|
inlineprotectedinherited |
void ugrpc::server::OutputStream< Response >::Finish | ( | ) |
Complete the RPC successfully.
Finish
must not be called multiple times.
ugrpc::server::RpcError | on an RPC error |
|
overridevirtual |
Complete the RPC with an error.
Finish
must not be called multiple times.
status | error details |
ugrpc::server::RpcError | on an RPC error |
Implements ugrpc::server::CallAnyBase.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
ServerContext
used for this RPC Finish
call
|
inlineinherited |
Get the span of the current RPC. Span's lifetime covers the Handle
call of the outermost middleware.
|
inlineprotectedinherited |
|
inlineinherited |
Returns call context for storing per-call custom data.
The context can be used to pass data from server middleware to client handler or from one middleware to another one.
In authentication middleware:
In client handler:
|
overridevirtual |
Useful for generic error reporting via FinishWithError.
Implements ugrpc::server::CallAnyBase.
|
overridevirtual |
Write the next outgoing message.
response | the next message to write |
ugrpc::server::RpcError | on an RPC error |
Implements ugrpc::server::Writer< Response >.
|
overridevirtual |
Write the next outgoing message.
response | the next message to write |
ugrpc::server::RpcError | on an RPC error |
Implements ugrpc::server::Writer< Response >.
void ugrpc::server::OutputStream< Response >::WriteAndFinish | ( | Response && | response | ) |
Equivalent to Write + Finish
This call saves one round-trip, compared to separate Write
and Finish
.
Finish
must not be called multiple times.
response | the final response message |
ugrpc::server::RpcError | on an RPC error |
void ugrpc::server::OutputStream< Response >::WriteAndFinish | ( | Response & | response | ) |
Equivalent to Write + Finish
This call saves one round-trip, compared to separate Write
and Finish
.
Finish
must not be called multiple times.
response | the final response message |
ugrpc::server::RpcError | on an RPC error |