GRPC C++  0.13.1-pre1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
client_context.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015-2016, Google Inc.
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are
8  * met:
9  *
10  * * Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above
13  * copyright notice, this list of conditions and the following disclaimer
14  * in the documentation and/or other materials provided with the
15  * distribution.
16  * * Neither the name of Google Inc. nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  *
32  */
33 
48 
49 #ifndef GRPCXX_IMPL_CODEGEN_CLIENT_CONTEXT_H
50 #define GRPCXX_IMPL_CODEGEN_CLIENT_CONTEXT_H
51 
52 #include <map>
53 #include <memory>
54 #include <string>
55 
62 #include <grpc/impl/codegen/compression_types.h>
63 #include <grpc/impl/codegen/log.h>
64 #include <grpc/impl/codegen/propagation_bits.h>
65 #include <grpc/impl/codegen/time.h>
66 
67 struct census_context;
68 struct grpc_call;
69 
70 namespace grpc {
71 
72 class Channel;
73 class ChannelInterface;
74 class CompletionQueue;
75 class CallCredentials;
76 class RpcMethod;
77 template <class R>
78 class ClientReader;
79 template <class W>
80 class ClientWriter;
81 template <class W, class R>
82 class ClientReaderWriter;
83 template <class R>
84 class ClientAsyncReader;
85 template <class W>
86 class ClientAsyncWriter;
87 template <class W, class R>
88 class ClientAsyncReaderWriter;
89 template <class R>
90 class ClientAsyncResponseReader;
91 class ServerContext;
92 
99  public:
100  PropagationOptions() : propagate_(GRPC_PROPAGATE_DEFAULTS) {}
101 
103  propagate_ |= GRPC_PROPAGATE_DEADLINE;
104  return *this;
105  }
106 
108  propagate_ &= ~GRPC_PROPAGATE_DEADLINE;
109  return *this;
110  }
111 
113  propagate_ |= GRPC_PROPAGATE_CENSUS_STATS_CONTEXT;
114  return *this;
115  }
116 
118  propagate_ &= ~GRPC_PROPAGATE_CENSUS_STATS_CONTEXT;
119  return *this;
120  }
121 
123  propagate_ |= GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT;
124  return *this;
125  }
126 
128  propagate_ &= ~GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT;
129  return *this;
130  }
131 
133  propagate_ |= GRPC_PROPAGATE_CANCELLATION;
134  return *this;
135  }
136 
138  propagate_ &= ~GRPC_PROPAGATE_CANCELLATION;
139  return *this;
140  }
141 
142  uint32_t c_bitmask() const { return propagate_; }
143 
144  private:
145  uint32_t propagate_;
146 };
147 
148 namespace testing {
149 class InteropClientContextInspector;
150 } // namespace testing
151 
153  public:
154  ClientContext();
155  ~ClientContext();
156 
167  static std::unique_ptr<ClientContext> FromServerContext(
168  const ServerContext& server_context,
170 
182  void AddMetadata(const grpc::string& meta_key,
183  const grpc::string& meta_value);
184 
193  const std::multimap<grpc::string_ref, grpc::string_ref>&
195  GPR_ASSERT(initial_metadata_received_);
196  return recv_initial_metadata_;
197  }
198 
205  const std::multimap<grpc::string_ref, grpc::string_ref>&
207  // TODO(yangg) check finished
208  return trailing_metadata_;
209  }
210 
217  template <typename T>
218  void set_deadline(const T& deadline) {
219  TimePoint<T> deadline_tp(deadline);
220  deadline_ = deadline_tp.raw_time();
221  }
222 
223 #ifndef GRPC_CXX0X_NO_CHRONO
224  std::chrono::system_clock::time_point deadline() {
226  return Timespec2Timepoint(deadline_);
227  }
228 #endif // !GRPC_CXX0X_NO_CHRONO
229 
231  gpr_timespec raw_deadline() { return deadline_; }
232 
235  void set_authority(const grpc::string& authority) { authority_ = authority; }
236 
240  std::shared_ptr<const AuthContext> auth_context() const;
241 
250  void set_credentials(const std::shared_ptr<CallCredentials>& creds) {
251  creds_ = creds;
252  }
253 
255  grpc_compression_algorithm compression_algorithm() const {
256  return compression_algorithm_;
257  }
258 
262  void set_compression_algorithm(grpc_compression_algorithm algorithm);
263 
271  grpc::string peer() const;
272 
274  void set_census_context(struct census_context* ccp) { census_context_ = ccp; }
275  struct census_context* census_context() const {
276  return census_context_;
277  }
278 
283  void TryCancel();
284 
290  public:
291  virtual ~GlobalCallbacks() {}
292  virtual void DefaultConstructor(ClientContext* context) = 0;
293  virtual void Destructor(ClientContext* context) = 0;
294  };
295  static void SetGlobalCallbacks(GlobalCallbacks* callbacks);
296 
297  private:
298  // Disallow copy and assign.
300  ClientContext& operator=(const ClientContext&);
301 
302  friend class ::grpc::testing::InteropClientContextInspector;
305  friend class Channel;
306  template <class R>
307  friend class ::grpc::ClientReader;
308  template <class W>
309  friend class ::grpc::ClientWriter;
310  template <class W, class R>
311  friend class ::grpc::ClientReaderWriter;
312  template <class R>
313  friend class ::grpc::ClientAsyncReader;
314  template <class W>
315  friend class ::grpc::ClientAsyncWriter;
316  template <class W, class R>
317  friend class ::grpc::ClientAsyncReaderWriter;
318  template <class R>
319  friend class ::grpc::ClientAsyncResponseReader;
320  template <class InputMessage, class OutputMessage>
321  friend Status BlockingUnaryCall(ChannelInterface* channel,
322  const RpcMethod& method,
323  ClientContext* context,
324  const InputMessage& request,
325  OutputMessage* result);
326 
327  grpc_call* call() { return call_; }
328  void set_call(grpc_call* call, const std::shared_ptr<Channel>& channel);
329 
330  grpc::string authority() { return authority_; }
331 
332  bool initial_metadata_received_;
333  std::shared_ptr<Channel> channel_;
334  grpc::mutex mu_;
335  grpc_call* call_;
336  bool call_canceled_;
337  gpr_timespec deadline_;
338  grpc::string authority_;
339  std::shared_ptr<CallCredentials> creds_;
340  mutable std::shared_ptr<const AuthContext> auth_context_;
341  struct census_context* census_context_;
342  std::multimap<grpc::string, grpc::string> send_initial_metadata_;
343  std::multimap<grpc::string_ref, grpc::string_ref> recv_initial_metadata_;
344  std::multimap<grpc::string_ref, grpc::string_ref> trailing_metadata_;
345 
346  grpc_call* propagate_from_call_;
347  PropagationOptions propagation_options_;
348 
349  grpc_compression_algorithm compression_algorithm_;
350 };
351 
352 } // namespace grpc
353 
354 #endif // GRPCXX_IMPL_CODEGEN_CLIENT_CONTEXT_H
PropagationOptions & enable_census_tracing_propagation()
Definition: client_context.h:122
PropagationOptions & enable_deadline_propagation()
Definition: client_context.h:102
std::string string
Definition: config.h:112
std::chrono::system_clock::time_point deadline()
Return the deadline for the client call.
Definition: client_context.h:225
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerTrailingMetadata()
Return a collection of trailing metadata key-value pairs.
Definition: client_context.h:206
Definition: call.h:431
void set_deadline(const T &deadline)
Set the deadline for the client call.
Definition: client_context.h:218
Definition: sync_no_cxx11.h:45
grpc::string peer() const
Return the peer uri in a string.
PropagationOptions & disable_cancellation_propagation()
Definition: client_context.h:137
PropagationOptions & enable_census_stats_propagation()
Definition: client_context.h:112
gpr_timespec raw_time()
Definition: time.h:57
Definition: time.h:54
PropagationOptions & enable_cancellation_propagation()
Definition: client_context.h:132
virtual void Destructor(ClientContext *context)=0
Definition: client_context.h:152
std::shared_ptr< const AuthContext > auth_context() const
Return the authentication context for this client call.
struct census_context * census_context() const
Definition: client_context.h:275
void TryCancel()
Send a best-effort out-of-band cancel.
Options for ClientContext::FromServerContext specifying which traits from the ServerContext to propag...
Definition: client_context.h:98
void set_census_context(struct census_context *ccp)
Get and set census context.
Definition: client_context.h:274
const std::multimap< grpc::string_ref, grpc::string_ref > & GetServerInitialMetadata()
Return a collection of initial metadata key-value pairs.
Definition: client_context.h:194
Global Callbacks.
Definition: client_context.h:289
grpc_compression_algorithm compression_algorithm() const
Return the compression algorithm to be used by the client call.
Definition: client_context.h:255
friend Status BlockingUnaryCall(ChannelInterface *channel, const RpcMethod &method, ClientContext *context, const InputMessage &request, OutputMessage *result)
Definition: client_unary_call.h:51
Codegen interface for grpc::Channel.
Definition: channel_interface.h:64
Definition: server_context.h:90
static void SetGlobalCallbacks(GlobalCallbacks *callbacks)
PropagationOptions & disable_census_tracing_propagation()
Definition: client_context.h:127
Definition: rpc_method.h:43
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:235
gpr_timespec raw_deadline()
Return a gpr_timespec representation of the client call's deadline.
Definition: client_context.h:231
Did it work? If it didn't, why?
Definition: status.h:45
std::chrono::system_clock::time_point Timespec2Timepoint(gpr_timespec t)
virtual void DefaultConstructor(ClientContext *context)=0
PropagationOptions()
Definition: client_context.h:100
uint32_t c_bitmask() const
Definition: client_context.h:142
void set_credentials(const std::shared_ptr< CallCredentials > &creds)
Set credentials for the client call.
Definition: client_context.h:250
void set_compression_algorithm(grpc_compression_algorithm algorithm)
Set algorithm to be the compression algorithm used for the client call.
Definition: call.h:401
PropagationOptions & disable_deadline_propagation()
Definition: client_context.h:107
static std::unique_ptr< ClientContext > FromServerContext(const ServerContext &server_context, PropagationOptions options=PropagationOptions())
Create a new ClientContext as a child of an incoming server call, according to options (...
void AddMetadata(const grpc::string &meta_key, const grpc::string &meta_value)
Add the (meta_key, meta_value) pair to the metadata associated with a client call.
PropagationOptions & disable_census_stats_propagation()
Definition: client_context.h:117
virtual ~GlobalCallbacks()
Definition: client_context.h:291
Channels represent a connection to an endpoint. Created by CreateChannel.
Definition: channel.h:49