34 #ifndef GRPCPP_IMPL_CODEGEN_CLIENT_CONTEXT_H 35 #define GRPCPP_IMPL_CODEGEN_CLIENT_CONTEXT_H 57 struct census_context;
68 class ChannelInterface;
73 class CallOpClientRecvStatus;
74 class CallOpRecvInitialMetadata;
75 template <
class InputMessage,
class OutputMessage>
76 class BlockingUnaryCallImpl;
77 template <
class InputMessage,
class OutputMessage>
78 class CallbackUnaryCallImpl;
79 template <
class Request,
class Response>
80 class ClientCallbackReaderWriterImpl;
81 template <
class Response>
82 class ClientCallbackReaderImpl;
83 template <
class Request>
84 class ClientCallbackWriterImpl;
85 class ClientCallbackUnaryImpl;
92 template <
class W,
class R>
93 class ClientReaderWriter;
95 class ClientAsyncReader;
97 class ClientAsyncWriter;
98 template <
class W,
class R>
99 class ClientAsyncReaderWriter;
101 class ClientAsyncResponseReader;
160 class InteropClientContextInspector;
194 static std::unique_ptr<ClientContext> FromServerContext(
226 const std::multimap<grpc::string_ref, grpc::string_ref>&
229 return *recv_initial_metadata_.map();
238 const std::multimap<grpc::string_ref, grpc::string_ref>&
241 return *trailing_metadata_.map();
250 template <
typename T>
275 wait_for_ready_ = wait_for_ready;
276 wait_for_ready_explicitly_set_ =
true;
283 std::chrono::system_clock::time_point
deadline()
const {
298 if (auth_context_.get() ==
nullptr) {
301 return auth_context_;
313 const std::shared_ptr<grpc_impl::CallCredentials>& creds) {
321 return compression_algorithm_;
340 initial_metadata_corked_ = corked;
355 return census_context_;
397 friend class ::grpc::testing::InteropClientContextInspector;
398 friend class ::grpc::internal::CallOpClientRecvStatus;
399 friend class ::grpc::internal::CallOpRecvInitialMetadata;
402 friend class ::grpc::ClientReader;
404 friend class ::grpc::ClientWriter;
405 template <
class W,
class R>
406 friend class ::grpc::ClientReaderWriter;
408 friend class ::grpc::ClientAsyncReader;
410 friend class ::grpc::ClientAsyncWriter;
411 template <
class W,
class R>
412 friend class ::grpc::ClientAsyncReaderWriter;
414 friend class ::grpc::ClientAsyncResponseReader;
415 template <
class InputMessage,
class OutputMessage>
416 friend class ::grpc::internal::BlockingUnaryCallImpl;
417 template <
class InputMessage,
class OutputMessage>
418 friend class ::grpc::internal::CallbackUnaryCallImpl;
419 template <
class Request,
class Response>
420 friend class ::grpc::internal::ClientCallbackReaderWriterImpl;
421 template <
class Response>
422 friend class ::grpc::internal::ClientCallbackReaderImpl;
423 template <
class Request>
424 friend class ::grpc::internal::ClientCallbackWriterImpl;
425 friend class ::grpc::internal::ClientCallbackUnaryImpl;
428 void set_debug_error_string(
const grpc::string& debug_error_string) {
429 debug_error_string_ = debug_error_string;
432 grpc_call* call()
const {
return call_; }
434 const std::shared_ptr<::grpc_impl::Channel>& channel);
440 std::unique_ptr<experimental::ClientInterceptorFactoryInterface>>&
442 size_t interceptor_pos) {
444 rpc_info_.RegisterInterceptors(creators, interceptor_pos);
448 uint32_t initial_metadata_flags()
const {
452 (wait_for_ready_explicitly_set_
460 void SendCancelToInterceptors();
462 bool initial_metadata_received_;
463 bool wait_for_ready_;
464 bool wait_for_ready_explicitly_set_;
467 std::shared_ptr<::grpc_impl::Channel> channel_;
473 std::shared_ptr<grpc_impl::CallCredentials> creds_;
474 mutable std::shared_ptr<const AuthContext> auth_context_;
475 struct census_context* census_context_;
476 std::multimap<grpc::string, grpc::string> send_initial_metadata_;
484 bool initial_metadata_corked_;
493 #endif // GRPCPP_IMPL_CODEGEN_CLIENT_CONTEXT_H const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerInitialMetadata() const
Return a collection of initial metadata key-value pairs.
Definition: client_context.h:227
struct grpc_call grpc_call
A Call represents an RPC.
Definition: grpc_types.h:70
std::shared_ptr< const AuthContext > CreateAuthContext(grpc_call *call)
grpc::string debug_error_string() const
EXPERIMENTAL debugging API.
Definition: client_context.h:390
struct census_context * census_context() const
Definition: client_context.h:354
void set_idempotent(bool idempotent)
EXPERIMENTAL: Indicate that this request is idempotent.
Definition: client_context.h:261
PropagationOptions & enable_census_tracing_propagation()
Definition: client_context.h:133
PropagationOptions & enable_deadline_propagation()
Definition: client_context.h:113
#define GPR_CODEGEN_ASSERT(x)
Codegen specific version of GPR_ASSERT.
Definition: core_codegen_interface.h:145
std::string string
Definition: config.h:35
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerTrailingMetadata() const
Return a collection of trailing metadata key-value pairs.
Definition: client_context.h:239
void set_wait_for_ready(bool wait_for_ready)
EXPERIMENTAL: Trigger wait-for-ready or not on this request.
Definition: client_context.h:274
grpc_call * c_call()
Should be used for framework-level extensions only.
Definition: client_context.h:383
void set_deadline(const T &deadline)
Set the deadline for the client call.
Definition: client_context.h:251
void set_initial_metadata_corked(bool corked)
Flag whether the initial metadata should be corked.
Definition: client_context.h:339
PropagationOptions & disable_cancellation_propagation()
Definition: client_context.h:148
PropagationOptions & enable_census_stats_propagation()
Definition: client_context.h:123
#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:447
gpr_timespec raw_time()
Definition: time.h:43
RpcType
Definition: rpc_method.h:31
If you are trying to use CompletionQueue::AsyncNext with a time class that isn't either gpr_timespec ...
Definition: time.h:40
PropagationOptions & enable_cancellation_propagation()
Definition: client_context.h:143
#define GRPC_INITIAL_METADATA_CORKED
Signal that the initial metadata should be corked.
Definition: grpc_types.h:449
void set_credentials(const std::shared_ptr< grpc_impl::CallCredentials > &creds)
Set credentials for the client call.
Definition: client_context.h:312
A ClientContext allows the person implementing a service client to:
Definition: client_context.h:179
uint32_t c_bitmask() const
Definition: client_context.h:153
Options for ClientContext::FromServerContext specifying which traits from the ServerContext to propag...
Definition: client_context.h:109
void set_fail_fast(bool fail_fast)
DEPRECATED: Use set_wait_for_ready() instead.
Definition: client_context.h:280
::grpc_impl::Channel Channel
Definition: channel.h:26
void set_census_context(struct census_context *ccp)
Get and set census context.
Definition: client_context.h:353
std::shared_ptr< const AuthContext > auth_context() const
Return the authentication context for this client call.
Definition: client_context.h:297
#define GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT
Definition: propagation_bits.h:34
::grpc_impl::CompletionQueue CompletionQueue
Definition: completion_queue.h:26
void set_cacheable(bool cacheable)
EXPERIMENTAL: Set this request to be cacheable.
Definition: client_context.h:266
Global Callbacks.
Definition: client_context.h:373
grpc_compression_algorithm
The various compression algorithms supported by gRPC (not sorted by compression level) ...
Definition: compression_types.h:57
grpc_compression_algorithm compression_algorithm() const
Return the compression algorithm the client call will request be used.
Definition: client_context.h:320
This header provides an object that reads bytes directly from a grpc::ByteBuffer, via the ZeroCopyInp...
Definition: alarm.h:24
::grpc_impl::CallCredentials CallCredentials
Definition: credentials.h:27
Codegen interface for grpc::Channel.
Definition: channel_interface.h:69
#define GRPC_INITIAL_METADATA_CACHEABLE_REQUEST
Signal that the call is cacheable.
Definition: grpc_types.h:444
A ServerContext allows the person implementing a service handler to:
Definition: server_context.h:114
PropagationOptions & disable_census_tracing_propagation()
Definition: client_context.h:138
An Alarm posts the user-provided tag to its associated completion queue or invokes the user-provided ...
Definition: alarm_impl.h:33
#define GRPC_INITIAL_METADATA_WAIT_FOR_READY
Signal that the call should not return UNAVAILABLE before it has started.
Definition: grpc_types.h:442
#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:43
#define GRPC_PROPAGATE_CENSUS_STATS_CONTEXT
Propagate census context.
Definition: propagation_bits.h:33
void set_authority(const grpc::string &authority)
Set the per call authority header (see https://tools.ietf.org/html/rfc7540#section-8.1.2.3).
Definition: client_context.h:292
Analogous to struct timespec.
Definition: gpr_types.h:47
std::chrono::system_clock::time_point Timespec2Timepoint(gpr_timespec t)
#define GRPC_PROPAGATE_DEADLINE
Propagation bits: this can be bitwise or-ed to form propagation_mask for grpc_call.
Definition: propagation_bits.h:31
PropagationOptions()
Definition: client_context.h:111
gpr_timespec raw_deadline() const
Return a gpr_timespec representation of the client call's deadline.
Definition: client_context.h:288
PropagationOptions & disable_deadline_propagation()
Definition: client_context.h:118
Definition: client_interceptor.h:70
std::chrono::system_clock::time_point deadline() const
Return the deadline for the client call.
Definition: client_context.h:283
PropagationOptions & disable_census_stats_propagation()
Definition: client_context.h:128
virtual ~GlobalCallbacks()
Definition: client_context.h:375
#define GRPC_INITIAL_METADATA_IDEMPOTENT_REQUEST
Initial metadata flags.
Definition: grpc_types.h:440
#define GRPC_PROPAGATE_CANCELLATION
Propagate cancellation.
Definition: propagation_bits.h:36