GRPC C++  1.24.0
client_context_impl.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015 gRPC authors.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  */
18 
33 
34 #ifndef GRPCPP_IMPL_CODEGEN_CLIENT_CONTEXT_IMPL_H
35 #define GRPCPP_IMPL_CODEGEN_CLIENT_CONTEXT_IMPL_H
36 
37 #include <map>
38 #include <memory>
39 #include <mutex>
40 #include <string>
41 
56 
57 struct census_context;
58 struct grpc_call;
59 
60 namespace grpc {
61 
62 class ChannelInterface;
63 
64 namespace internal {
65 class RpcMethod;
66 template <class InputMessage, class OutputMessage>
67 class BlockingUnaryCallImpl;
68 class CallOpClientRecvStatus;
69 class CallOpRecvInitialMetadata;
70 } // namespace internal
71 
72 namespace testing {
73 class InteropClientContextInspector;
74 } // namespace testing
75 } // namespace grpc
76 namespace grpc_impl {
77 
78 namespace internal {
79 template <class InputMessage, class OutputMessage>
80 class CallbackUnaryCallImpl;
81 template <class Request, class Response>
82 class ClientCallbackReaderWriterImpl;
83 template <class Response>
84 class ClientCallbackReaderImpl;
85 template <class Request>
86 class ClientCallbackWriterImpl;
87 class ClientCallbackUnaryImpl;
88 class ClientContextAccessor;
89 } // namespace internal
90 
91 class CallCredentials;
92 class Channel;
93 class CompletionQueue;
94 class ServerContext;
95 template <class R>
96 class ClientReader;
97 template <class W>
98 class ClientWriter;
99 template <class W, class R>
100 class ClientReaderWriter;
101 template <class R>
102 class ClientAsyncReader;
103 template <class W>
104 class ClientAsyncWriter;
105 template <class W, class R>
107 template <class R>
109 
116  public:
118 
120  propagate_ |= GRPC_PROPAGATE_DEADLINE;
121  return *this;
122  }
123 
125  propagate_ &= ~GRPC_PROPAGATE_DEADLINE;
126  return *this;
127  }
128 
131  return *this;
132  }
133 
136  return *this;
137  }
138 
141  return *this;
142  }
143 
146  return *this;
147  }
148 
150  propagate_ |= GRPC_PROPAGATE_CANCELLATION;
151  return *this;
152  }
153 
155  propagate_ &= ~GRPC_PROPAGATE_CANCELLATION;
156  return *this;
157  }
158 
159  uint32_t c_bitmask() const { return propagate_; }
160 
161  private:
162  uint32_t propagate_;
163 };
164 
182  public:
183  ClientContext();
184  ~ClientContext();
185 
196  static std::unique_ptr<ClientContext> FromServerContext(
197  const grpc_impl::ServerContext& server_context,
199 
217  void AddMetadata(const grpc::string& meta_key,
218  const grpc::string& meta_value);
219 
228  const std::multimap<grpc::string_ref, grpc::string_ref>&
230  GPR_CODEGEN_ASSERT(initial_metadata_received_);
231  return *recv_initial_metadata_.map();
232  }
233 
240  const std::multimap<grpc::string_ref, grpc::string_ref>&
242  // TODO(yangg) check finished
243  return *trailing_metadata_.map();
244  }
245 
252  template <typename T>
253  void set_deadline(const T& deadline) {
254  grpc::TimePoint<T> deadline_tp(deadline);
255  deadline_ = deadline_tp.raw_time();
256  }
257 
263  void set_idempotent(bool idempotent) { idempotent_ = idempotent; }
264 
268  void set_cacheable(bool cacheable) { cacheable_ = cacheable; }
269 
276  void set_wait_for_ready(bool wait_for_ready) {
277  wait_for_ready_ = wait_for_ready;
278  wait_for_ready_explicitly_set_ = true;
279  }
280 
282  void set_fail_fast(bool fail_fast) { set_wait_for_ready(!fail_fast); }
283 
285  std::chrono::system_clock::time_point deadline() const {
286  return grpc::Timespec2Timepoint(deadline_);
287  }
288 
290  gpr_timespec raw_deadline() const { return deadline_; }
291 
294  void set_authority(const grpc::string& authority) { authority_ = authority; }
295 
299  std::shared_ptr<const grpc::AuthContext> auth_context() const {
300  if (auth_context_.get() == nullptr) {
301  auth_context_ = grpc::CreateAuthContext(call_);
302  }
303  return auth_context_;
304  }
305 
316  void set_credentials(
317  const std::shared_ptr<grpc_impl::CallCredentials>& creds);
318 
323  return compression_algorithm_;
324  }
325 
329  void set_compression_algorithm(grpc_compression_algorithm algorithm);
330 
341  void set_initial_metadata_corked(bool corked) {
342  initial_metadata_corked_ = corked;
343  }
344 
352  grpc::string peer() const;
353 
355  void set_census_context(struct census_context* ccp) { census_context_ = ccp; }
356  struct census_context* census_context() const {
357  return census_context_;
358  }
359 
369  void TryCancel();
370 
376  public:
377  virtual ~GlobalCallbacks() {}
378  virtual void DefaultConstructor(ClientContext* context) = 0;
379  virtual void Destructor(ClientContext* context) = 0;
380  };
381  static void SetGlobalCallbacks(GlobalCallbacks* callbacks);
382 
385  grpc_call* c_call() { return call_; }
386 
392  grpc::string debug_error_string() const { return debug_error_string_; }
393 
394  private:
395  // Disallow copy and assign.
397  ClientContext& operator=(const ClientContext&);
398 
399  friend class ::grpc::testing::InteropClientContextInspector;
400  friend class ::grpc::internal::CallOpClientRecvStatus;
401  friend class ::grpc::internal::CallOpRecvInitialMetadata;
403  template <class R>
405  template <class W>
407  template <class W, class R>
409  template <class R>
411  template <class W>
413  template <class W, class R>
415  template <class R>
417  template <class InputMessage, class OutputMessage>
418  friend class ::grpc::internal::BlockingUnaryCallImpl;
419  template <class InputMessage, class OutputMessage>
420  friend class ::grpc_impl::internal::CallbackUnaryCallImpl;
421  template <class Request, class Response>
422  friend class ::grpc_impl::internal::ClientCallbackReaderWriterImpl;
423  template <class Response>
424  friend class ::grpc_impl::internal::ClientCallbackReaderImpl;
425  template <class Request>
426  friend class ::grpc_impl::internal::ClientCallbackWriterImpl;
427  friend class ::grpc_impl::internal::ClientCallbackUnaryImpl;
428  friend class ::grpc_impl::internal::ClientContextAccessor;
429 
430  // Used by friend class CallOpClientRecvStatus
431  void set_debug_error_string(const grpc::string& debug_error_string) {
432  debug_error_string_ = debug_error_string;
433  }
434 
435  grpc_call* call() const { return call_; }
436  void set_call(grpc_call* call,
437  const std::shared_ptr<::grpc_impl::Channel>& channel);
438 
439  grpc::experimental::ClientRpcInfo* set_client_rpc_info(
440  const char* method, grpc::internal::RpcMethod::RpcType type,
441  grpc::ChannelInterface* channel,
442  const std::vector<std::unique_ptr<
444  size_t interceptor_pos) {
445  rpc_info_ = grpc::experimental::ClientRpcInfo(this, type, method, channel);
446  rpc_info_.RegisterInterceptors(creators, interceptor_pos);
447  return &rpc_info_;
448  }
449 
450  uint32_t initial_metadata_flags() const {
451  return (idempotent_ ? GRPC_INITIAL_METADATA_IDEMPOTENT_REQUEST : 0) |
452  (wait_for_ready_ ? GRPC_INITIAL_METADATA_WAIT_FOR_READY : 0) |
453  (cacheable_ ? GRPC_INITIAL_METADATA_CACHEABLE_REQUEST : 0) |
454  (wait_for_ready_explicitly_set_
456  : 0) |
457  (initial_metadata_corked_ ? GRPC_INITIAL_METADATA_CORKED : 0);
458  }
459 
460  grpc::string authority() { return authority_; }
461 
462  void SendCancelToInterceptors();
463 
464  bool initial_metadata_received_;
465  bool wait_for_ready_;
466  bool wait_for_ready_explicitly_set_;
467  bool idempotent_;
468  bool cacheable_;
469  std::shared_ptr<::grpc_impl::Channel> channel_;
471  grpc_call* call_;
472  bool call_canceled_;
473  gpr_timespec deadline_;
474  grpc::string authority_;
475  std::shared_ptr<grpc_impl::CallCredentials> creds_;
476  mutable std::shared_ptr<const grpc::AuthContext> auth_context_;
477  struct census_context* census_context_;
478  std::multimap<grpc::string, grpc::string> send_initial_metadata_;
479  mutable grpc::internal::MetadataMap recv_initial_metadata_;
480  mutable grpc::internal::MetadataMap trailing_metadata_;
481 
482  grpc_call* propagate_from_call_;
483  PropagationOptions propagation_options_;
484 
485  grpc_compression_algorithm compression_algorithm_;
486  bool initial_metadata_corked_;
487 
488  grpc::string debug_error_string_;
489 
491 };
492 
493 } // namespace grpc_impl
494 
495 #endif // GRPCPP_IMPL_CODEGEN_CLIENT_CONTEXT_IMPL_H
void set_idempotent(bool idempotent)
EXPERIMENTAL: Indicate that this request is idempotent.
Definition: client_context_impl.h:263
struct census_context * census_context() const
Definition: client_context_impl.h:356
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_impl::ClientAsyncReader< R > ClientAsyncReader
Definition: async_stream.h:43
::grpc_impl::ClientContext ClientContext
Definition: client_context.h:26
std::shared_ptr< const grpc::AuthContext > auth_context() const
Return the authentication context for this client call.
Definition: client_context_impl.h:299
PropagationOptions & disable_deadline_propagation()
Definition: client_context_impl.h:124
grpc_call * c_call()
Should be used for framework-level extensions only.
Definition: client_context_impl.h:385
PropagationOptions & enable_deadline_propagation()
Definition: client_context_impl.h:119
#define GPR_CODEGEN_ASSERT(x)
Codegen specific version of GPR_ASSERT.
Definition: core_codegen_interface.h:145
Synchronous (blocking) client-side API for bi-directional streaming RPCs, where the outgoing message ...
Definition: channel_interface.h:35
void set_cacheable(bool cacheable)
EXPERIMENTAL: Set this request to be cacheable.
Definition: client_context_impl.h:268
std::string string
Definition: config.h:35
PropagationOptions & enable_cancellation_propagation()
Definition: client_context_impl.h:149
grpc::string debug_error_string() const
EXPERIMENTAL debugging API.
Definition: client_context_impl.h:392
A call credentials object encapsulates the state needed by a client to authenticate with a server for...
Definition: credentials_impl.h:110
Synchronous (blocking) client-side API for doing server-streaming RPCs, where the stream of messages ...
Definition: channel_interface.h:31
Definition: metadata_map.h:33
PropagationOptions()
Definition: client_context_impl.h:117
PropagationOptions & enable_census_tracing_propagation()
Definition: client_context_impl.h:139
PropagationOptions & enable_census_stats_propagation()
Definition: client_context_impl.h:129
::grpc_impl::PropagationOptions PropagationOptions
Definition: client_context.h:27
Async client-side interface for bi-directional streaming, where the outgoing message stream going to ...
Definition: async_stream_impl.h:513
::grpc_impl::ClientAsyncReaderWriter< W, R > ClientAsyncReaderWriter
Definition: async_stream.h:56
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerInitialMetadata() const
Return a collection of initial metadata key-value pairs.
Definition: client_context_impl.h:229
Options for ClientContext::FromServerContext specifying which traits from the ServerContext to propag...
Definition: client_context_impl.h:115
grpc_compression_algorithm compression_algorithm() const
Return the compression algorithm the client call will request be used.
Definition: client_context_impl.h:322
#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:457
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&#39;t either gpr_timespec ...
Definition: time.h:40
A ServerContext allows the person implementing a service handler to:
Definition: server_context_impl.h:118
#define GRPC_INITIAL_METADATA_CORKED
Signal that the initial metadata should be corked.
Definition: grpc_types.h:459
PropagationOptions & disable_cancellation_propagation()
Definition: client_context_impl.h:154
void set_initial_metadata_corked(bool corked)
Flag whether the initial metadata should be corked.
Definition: client_context_impl.h:341
Async client-side API for doing server-streaming RPCs, where the incoming message stream coming from ...
Definition: async_stream_impl.h:197
gpr_timespec raw_deadline() const
Return a gpr_timespec representation of the client call&#39;s deadline.
Definition: client_context_impl.h:290
PropagationOptions & disable_census_tracing_propagation()
Definition: client_context_impl.h:144
::grpc_impl::Channel Channel
Definition: channel.h:26
#define GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT
Definition: propagation_bits.h:34
std::chrono::system_clock::time_point deadline() const
Return the deadline for the client call.
Definition: client_context_impl.h:285
grpc_compression_algorithm
The various compression algorithms supported by gRPC (not sorted by compression level) ...
Definition: compression_types.h:57
Definition: sync.h:47
Async API for client-side unary RPCs, where the message response received from the server is of type ...
Definition: async_unary_call_impl.h:95
::grpc_impl::ClientReaderWriter< W, R > ClientReaderWriter
Definition: sync_stream.h:69
This header provides an object that reads bytes directly from a grpc::ByteBuffer, via the ZeroCopyInp...
Definition: alarm.h:24
Codegen interface for grpc::Channel.
Definition: channel_interface.h:74
#define GRPC_INITIAL_METADATA_CACHEABLE_REQUEST
Signal that the call is cacheable.
Definition: grpc_types.h:454
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_impl.h:294
::grpc_impl::ClientWriter< W > ClientWriter
Definition: sync_stream.h:62
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:452
void set_deadline(const T &deadline)
Set the deadline for the client call.
Definition: client_context_impl.h:253
void set_fail_fast(bool fail_fast)
DEPRECATED: Use set_wait_for_ready() instead.
Definition: client_context_impl.h:282
#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
Async API on the client side for doing client-streaming RPCs, where the outgoing message stream going...
Definition: async_stream_impl.h:346
Global Callbacks.
Definition: client_context_impl.h:375
#define GRPC_PROPAGATE_CENSUS_STATS_CONTEXT
Propagate census context.
Definition: propagation_bits.h:33
void set_census_context(struct census_context *ccp)
Get and set census context.
Definition: client_context_impl.h:355
A thin wrapper around grpc_completion_queue (see src/core/lib/surface/completion_queue.h).
Definition: completion_queue_impl.h:101
A ClientContext allows the person implementing a service client to:
Definition: client_context_impl.h:181
Channels represent a connection to an endpoint. Created by CreateChannel.
Definition: channel_impl.h:54
::grpc_impl::ClientAsyncWriter< W > ClientAsyncWriter
Definition: async_stream.h:49
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
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerTrailingMetadata() const
Return a collection of trailing metadata key-value pairs.
Definition: client_context_impl.h:241
Synchronous (blocking) client-side API for doing client-streaming RPCs, where the outgoing message st...
Definition: channel_interface.h:33
PropagationOptions & disable_census_stats_propagation()
Definition: client_context_impl.h:134
virtual ~GlobalCallbacks()
Definition: client_context_impl.h:377
::grpc_impl::ClientReader< R > ClientReader
Definition: sync_stream.h:56
uint32_t c_bitmask() const
Definition: client_context_impl.h:159
Definition: client_interceptor.h:69
grpc_impl::ClientAsyncResponseReader< R > ClientAsyncResponseReader
Definition: async_unary_call.h:31
void set_wait_for_ready(bool wait_for_ready)
EXPERIMENTAL: Trigger wait-for-ready or not on this request.
Definition: client_context_impl.h:276
#define GRPC_INITIAL_METADATA_IDEMPOTENT_REQUEST
Initial metadata flags.
Definition: grpc_types.h:450
#define GRPC_PROPAGATE_CANCELLATION
Propagate cancellation.
Definition: propagation_bits.h:36