Go to the documentation of this file.
34 #ifndef GRPCPP_CLIENT_CONTEXT_H
35 #define GRPCPP_CLIENT_CONTEXT_H
41 #include "absl/log/absl_check.h"
63 class ServerContextBase;
64 class CallbackServerContext;
67 template <
class InputMessage,
class OutputMessage>
69 template <
class Request,
class Response>
71 template <
class Response>
73 template <
class Request>
76 class ClientContextAccessor;
84 template <
class W,
class R>
90 template <
class W,
class R>
96 class InteropClientContextInspector;
97 class ClientContextTestPeer;
102 template <
class InputMessage,
class OutputMessage>
106 class ServerContextImpl;
107 template <
class InputMessage,
class OutputMessage>
109 template <
class Request,
class Response>
111 template <
class Response>
113 template <
class Request>
116 class ClientContextAccessor;
239 void AddMetadata(
const std::string& meta_key,
const std::string& meta_value);
249 const std::multimap<grpc::string_ref, grpc::string_ref>&
251 ABSL_CHECK(initial_metadata_received_);
252 return *recv_initial_metadata_.
map();
261 const std::multimap<grpc::string_ref, grpc::string_ref>&
264 return *trailing_metadata_.
map();
273 template <
typename T>
286 wait_for_ready_ = wait_for_ready;
287 wait_for_ready_explicitly_set_ =
true;
294 std::chrono::system_clock::time_point
deadline()
const {
303 void set_authority(
const std::string& authority) { authority_ = authority; }
310 if (auth_context_ ==
nullptr) {
313 return auth_context_;
326 void set_credentials(
const std::shared_ptr<grpc::CallCredentials>& creds);
333 std::shared_ptr<grpc::CallCredentials>
credentials() {
return creds_; }
339 return compression_algorithm_;
358 initial_metadata_corked_ = corked;
369 std::string
peer()
const;
431 template <
class W,
class R>
437 template <
class W,
class R>
442 template <
class InputMessage,
class OutputMessage>
444 template <
class InputMessage,
class OutputMessage>
446 template <
class Request,
class Response>
448 template <
class Response>
450 template <
class Request>
460 grpc_call* call()
const {
return call_; }
461 void set_call(
grpc_call* call,
const std::shared_ptr<grpc::Channel>& channel);
464 const char* method,
const char* suffix_for_stats,
466 const std::vector<std::unique_ptr<
468 size_t interceptor_pos) {
470 suffix_for_stats, channel);
471 rpc_info_.RegisterInterceptors(creators, interceptor_pos);
475 uint32_t initial_metadata_flags()
const {
477 (wait_for_ready_explicitly_set_
482 std::string authority() {
return authority_; }
484 void SendCancelToInterceptors();
486 static std::unique_ptr<ClientContext> FromInternalServerContext(
488 PropagationOptions options);
490 bool initial_metadata_received_;
491 bool wait_for_ready_;
492 bool wait_for_ready_explicitly_set_;
493 std::shared_ptr<grpc::Channel> channel_;
498 grpc::string authority_;
499 std::shared_ptr<grpc::CallCredentials> creds_;
500 mutable std::shared_ptr<const grpc::AuthContext> auth_context_;
502 std::multimap<std::string, std::string> send_initial_metadata_;
507 PropagationOptions propagation_options_;
510 bool initial_metadata_corked_;
512 std::string debug_error_string_;
519 #endif // GRPCPP_CLIENT_CONTEXT_H
Definition: client_callback.h:1111
struct census_context census_context
A Census Context is a handle used by Census to represent the current tracing and stats collection inf...
Definition: census.h:33
static std::unique_ptr< ClientContext > FromServerContext(const grpc::ServerContextBase &server_context, PropagationOptions options=PropagationOptions())
Create a new ClientContext as a child of an incoming server call, according to options (.
grpc_compression_algorithm compression_algorithm() const
Return the compression algorithm the client call will request be used.
Definition: client_context.h:338
void set_credentials(const std::shared_ptr< grpc::CallCredentials > &creds)
Set credentials for the client call.
Definition: client_context.h:70
Synchronous (blocking) client-side API for doing client-streaming RPCs, where the outgoing message st...
Definition: client_context.h:83
virtual void Destructor(ClientContext *context)=0
An Alarm posts the user-provided tag to its associated completion queue or invokes the user-provided ...
Definition: alarm.h:33
void set_wait_for_ready(bool wait_for_ready)
Trigger wait-for-ready or not on this request.
Definition: client_context.h:285
Definition: server_context.h:618
void set_deadline(const T &deadline)
Set the deadline for the client call.
Definition: client_context.h:274
grpc_compression_algorithm
The various compression algorithms supported by gRPC (not sorted by compression level)
Definition: compression_types.h:60
virtual ~GlobalCallbacks()
Definition: client_context.h:400
Definition: client_context.h:103
Options for ClientContext::FromServerContext specifying which traits from the ServerContext to propag...
Definition: client_context.h:129
Base class of ServerContext.
Definition: server_context.h:124
virtual void DefaultConstructor(ClientContext *context)=0
std::string peer() const
Return the peer uri in a string.
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerInitialMetadata() const
Return a collection of initial metadata key-value pairs.
Definition: client_context.h:250
gpr_timespec raw_deadline() const
Return a gpr_timespec representation of the client call's deadline.
Definition: client_context.h:299
PropagationOptions()
Definition: client_context.h:131
PropagationOptions & disable_census_stats_propagation()
Definition: client_context.h:148
void set_census_context(struct census_context *ccp)
Sets the census context.
Definition: client_context.h:375
void AddMetadata(const std::string &meta_key, const std::string &meta_value)
Add the (meta_key, meta_value) pair to the metadata associated with a client call.
PropagationOptions & disable_census_tracing_propagation()
Definition: client_context.h:158
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerTrailingMetadata() const
Return a collection of trailing metadata key-value pairs.
Definition: client_context.h:262
Definition: client_interceptor.h:72
A call credentials object encapsulates the state needed by a client to authenticate with a server for...
Definition: credentials.h:115
#define GRPC_INITIAL_METADATA_WAIT_FOR_READY
Initial metadata flags.
Definition: grpc_types.h:199
Synchronous (blocking) client-side API for doing server-streaming RPCs, where the stream of messages ...
Definition: client_context.h:81
std::shared_ptr< const AuthContext > CreateAuthContext(grpc_call *call)
TODO(ctiller): not sure we want to make this a permanent thing.
#define GRPC_INITIAL_METADATA_WAIT_FOR_READY_EXPLICITLY_SET
Signal that GRPC_INITIAL_METADATA_WAIT_FOR_READY was explicitly set by the calling application.
Definition: grpc_types.h:202
A ClientContext allows the person implementing a service client to:
Definition: client_context.h:195
PropagationOptions & disable_deadline_propagation()
Definition: client_context.h:138
Async API for client-side unary RPCs, where the message response received from the server is of type ...
Definition: client_context.h:93
struct grpc_call grpc_call
A Call represents an RPC.
Definition: grpc_types.h:69
void TryCancel()
Send a best-effort out-of-band cancel on the call associated with this client context.
friend class grpc::testing::ClientContextTestPeer
Definition: client_context.h:423
Definition: client_context.h:68
gpr_timespec raw_time()=delete
#define GRPC_PROPAGATE_CENSUS_STATS_CONTEXT
Propagate census context.
Definition: propagation_bits.h:35
Async client-side API for doing server-streaming RPCs, where the incoming message stream coming from ...
Definition: client_context.h:87
friend class grpc::testing::InteropClientContextInspector
Definition: client_context.h:422
Codegen interface for grpc::Channel.
Definition: channel_interface.h:71
static void SetGlobalCallbacks(GlobalCallbacks *callbacks)
Definition: async_unary_call.h:80
Definition: client_context.h:74
std::chrono::system_clock::time_point deadline() const
Return the deadline for the client call.
Definition: client_context.h:294
RpcType
Definition: rpc_method.h:31
PropagationOptions & enable_cancellation_propagation()
Definition: client_context.h:163
PropagationOptions & enable_deadline_propagation()
Definition: client_context.h:133
friend class grpc::internal::ClientContextAccessor
Definition: client_context.h:453
Async API on the client side for doing client-streaming RPCs, where the outgoing message stream going...
Definition: client_context.h:89
void set_fail_fast(bool fail_fast)
DEPRECATED: Use set_wait_for_ready() instead.
Definition: client_context.h:291
#define GRPC_PROPAGATE_DEFAULTS
Default propagation mask: clients of the core API are encouraged to encode deltas from this in their ...
Definition: propagation_bits.h:45
uint32_t c_bitmask() const
Definition: client_context.h:173
Async client-side interface for bi-directional streaming, where the outgoing message stream going to ...
Definition: client_context.h:91
PropagationOptions & enable_census_tracing_propagation()
Definition: client_context.h:153
Definition: client_interceptor.h:49
void set_initial_metadata_corked(bool corked)
Flag whether the initial metadata should be corked.
Definition: client_context.h:357
#define GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT
Definition: propagation_bits.h:36
Synchronous (blocking) client-side API for bi-directional streaming RPCs, where the outgoing message ...
Definition: client_context.h:85
Global Callbacks.
Definition: client_context.h:398
static std::unique_ptr< ClientContext > FromCallbackServerContext(const grpc::CallbackServerContext &server_context, PropagationOptions options=PropagationOptions())
Definition: call_op_set.h:771
A thin wrapper around grpc_completion_queue (see src/core/lib/surface/completion_queue....
Definition: completion_queue.h:105
Channels represent a connection to an endpoint. Created by CreateChannel.
Definition: channel.h:54
Definition: client_context.h:72
std::shared_ptr< const grpc::AuthContext > auth_context() const
Return the authentication context for the associated client call.
Definition: client_context.h:309
PropagationOptions & enable_census_stats_propagation()
Definition: client_context.h:143
PropagationOptions & disable_cancellation_propagation()
Definition: client_context.h:168
#define GRPC_PROPAGATE_DEADLINE
Propagation bits: this can be bitwise or-ed to form propagation_mask for grpc_call.
Definition: propagation_bits.h:33
Analogous to struct timespec.
Definition: time.h:48
std::shared_ptr< grpc::CallCredentials > credentials()
EXPERIMENTAL debugging API.
Definition: client_context.h:333
void set_authority(const std::string &authority)
Set the per call authority header (see https://tools.ietf.org/html/rfc7540#section-8....
Definition: client_context.h:303
std::string debug_error_string() const
EXPERIMENTAL debugging API.
Definition: client_context.h:415
struct census_context * census_context() const
Returns the census context that has been set, or nullptr if not set.
Definition: client_context.h:378
std::chrono::system_clock::time_point Timespec2Timepoint(gpr_timespec t)
If you are trying to use CompletionQueue::AsyncNext with a time class that isn't either gpr_timespec ...
Definition: time.h:40
grpc_call * c_call()
Should be used for framework-level extensions only.
Definition: client_context.h:408
void set_compression_algorithm(grpc_compression_algorithm algorithm)
Set algorithm to be the compression algorithm used for the client call.
#define GRPC_PROPAGATE_CANCELLATION
Propagate cancellation.
Definition: propagation_bits.h:38