1*cc02d7e2SAndroid Build Coastguard Worker // 2*cc02d7e2SAndroid Build Coastguard Worker // 3*cc02d7e2SAndroid Build Coastguard Worker // Copyright 2015 gRPC authors. 4*cc02d7e2SAndroid Build Coastguard Worker // 5*cc02d7e2SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 6*cc02d7e2SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 7*cc02d7e2SAndroid Build Coastguard Worker // You may obtain a copy of the License at 8*cc02d7e2SAndroid Build Coastguard Worker // 9*cc02d7e2SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0 10*cc02d7e2SAndroid Build Coastguard Worker // 11*cc02d7e2SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 12*cc02d7e2SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 13*cc02d7e2SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*cc02d7e2SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 15*cc02d7e2SAndroid Build Coastguard Worker // limitations under the License. 16*cc02d7e2SAndroid Build Coastguard Worker // 17*cc02d7e2SAndroid Build Coastguard Worker // 18*cc02d7e2SAndroid Build Coastguard Worker 19*cc02d7e2SAndroid Build Coastguard Worker /// A ClientContext allows the person implementing a service client to: 20*cc02d7e2SAndroid Build Coastguard Worker /// 21*cc02d7e2SAndroid Build Coastguard Worker /// - Add custom metadata key-value pairs that will propagated to the server 22*cc02d7e2SAndroid Build Coastguard Worker /// side. 23*cc02d7e2SAndroid Build Coastguard Worker /// - Control call settings such as compression and authentication. 24*cc02d7e2SAndroid Build Coastguard Worker /// - Initial and trailing metadata coming from the server. 25*cc02d7e2SAndroid Build Coastguard Worker /// - Get performance metrics (ie, census). 26*cc02d7e2SAndroid Build Coastguard Worker /// 27*cc02d7e2SAndroid Build Coastguard Worker /// Context settings are only relevant to the call they are invoked with, that 28*cc02d7e2SAndroid Build Coastguard Worker /// is to say, they aren't sticky. Some of these settings, such as the 29*cc02d7e2SAndroid Build Coastguard Worker /// compression options, can be made persistent at channel construction time 30*cc02d7e2SAndroid Build Coastguard Worker /// (see \a grpc::CreateCustomChannel). 31*cc02d7e2SAndroid Build Coastguard Worker /// 32*cc02d7e2SAndroid Build Coastguard Worker /// \warning ClientContext instances should \em not be reused across rpcs. 33*cc02d7e2SAndroid Build Coastguard Worker 34*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPCPP_CLIENT_CONTEXT_H 35*cc02d7e2SAndroid Build Coastguard Worker #define GRPCPP_CLIENT_CONTEXT_H 36*cc02d7e2SAndroid Build Coastguard Worker 37*cc02d7e2SAndroid Build Coastguard Worker #include <map> 38*cc02d7e2SAndroid Build Coastguard Worker #include <memory> 39*cc02d7e2SAndroid Build Coastguard Worker #include <string> 40*cc02d7e2SAndroid Build Coastguard Worker 41*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/impl/compression_types.h> 42*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/impl/propagation_bits.h> 43*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/support/log.h> 44*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/impl/create_auth_context.h> 45*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/impl/metadata_map.h> 46*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/impl/rpc_method.h> 47*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/impl/sync.h> 48*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/security/auth_context.h> 49*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/client_interceptor.h> 50*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/config.h> 51*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/slice.h> 52*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/status.h> 53*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/string_ref.h> 54*cc02d7e2SAndroid Build Coastguard Worker #include <grpcpp/support/time.h> 55*cc02d7e2SAndroid Build Coastguard Worker 56*cc02d7e2SAndroid Build Coastguard Worker struct census_context; 57*cc02d7e2SAndroid Build Coastguard Worker struct grpc_call; 58*cc02d7e2SAndroid Build Coastguard Worker 59*cc02d7e2SAndroid Build Coastguard Worker namespace grpc { 60*cc02d7e2SAndroid Build Coastguard Worker class ServerContext; 61*cc02d7e2SAndroid Build Coastguard Worker class ServerContextBase; 62*cc02d7e2SAndroid Build Coastguard Worker class CallbackServerContext; 63*cc02d7e2SAndroid Build Coastguard Worker 64*cc02d7e2SAndroid Build Coastguard Worker namespace internal { 65*cc02d7e2SAndroid Build Coastguard Worker template <class InputMessage, class OutputMessage> 66*cc02d7e2SAndroid Build Coastguard Worker class CallbackUnaryCallImpl; 67*cc02d7e2SAndroid Build Coastguard Worker template <class Request, class Response> 68*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackReaderWriterImpl; 69*cc02d7e2SAndroid Build Coastguard Worker template <class Response> 70*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackReaderImpl; 71*cc02d7e2SAndroid Build Coastguard Worker template <class Request> 72*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackWriterImpl; 73*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackUnaryImpl; 74*cc02d7e2SAndroid Build Coastguard Worker class ClientContextAccessor; 75*cc02d7e2SAndroid Build Coastguard Worker class ClientAsyncResponseReaderHelper; 76*cc02d7e2SAndroid Build Coastguard Worker } // namespace internal 77*cc02d7e2SAndroid Build Coastguard Worker 78*cc02d7e2SAndroid Build Coastguard Worker template <class R> 79*cc02d7e2SAndroid Build Coastguard Worker class ClientReader; 80*cc02d7e2SAndroid Build Coastguard Worker template <class W> 81*cc02d7e2SAndroid Build Coastguard Worker class ClientWriter; 82*cc02d7e2SAndroid Build Coastguard Worker template <class W, class R> 83*cc02d7e2SAndroid Build Coastguard Worker class ClientReaderWriter; 84*cc02d7e2SAndroid Build Coastguard Worker template <class R> 85*cc02d7e2SAndroid Build Coastguard Worker class ClientAsyncReader; 86*cc02d7e2SAndroid Build Coastguard Worker template <class W> 87*cc02d7e2SAndroid Build Coastguard Worker class ClientAsyncWriter; 88*cc02d7e2SAndroid Build Coastguard Worker template <class W, class R> 89*cc02d7e2SAndroid Build Coastguard Worker class ClientAsyncReaderWriter; 90*cc02d7e2SAndroid Build Coastguard Worker template <class R> 91*cc02d7e2SAndroid Build Coastguard Worker class ClientAsyncResponseReader; 92*cc02d7e2SAndroid Build Coastguard Worker 93*cc02d7e2SAndroid Build Coastguard Worker namespace testing { 94*cc02d7e2SAndroid Build Coastguard Worker class InteropClientContextInspector; 95*cc02d7e2SAndroid Build Coastguard Worker class ClientContextTestPeer; 96*cc02d7e2SAndroid Build Coastguard Worker } // namespace testing 97*cc02d7e2SAndroid Build Coastguard Worker 98*cc02d7e2SAndroid Build Coastguard Worker namespace internal { 99*cc02d7e2SAndroid Build Coastguard Worker class RpcMethod; 100*cc02d7e2SAndroid Build Coastguard Worker template <class InputMessage, class OutputMessage> 101*cc02d7e2SAndroid Build Coastguard Worker class BlockingUnaryCallImpl; 102*cc02d7e2SAndroid Build Coastguard Worker class CallOpClientRecvStatus; 103*cc02d7e2SAndroid Build Coastguard Worker class CallOpRecvInitialMetadata; 104*cc02d7e2SAndroid Build Coastguard Worker class ServerContextImpl; 105*cc02d7e2SAndroid Build Coastguard Worker template <class InputMessage, class OutputMessage> 106*cc02d7e2SAndroid Build Coastguard Worker class CallbackUnaryCallImpl; 107*cc02d7e2SAndroid Build Coastguard Worker template <class Request, class Response> 108*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackReaderWriterImpl; 109*cc02d7e2SAndroid Build Coastguard Worker template <class Response> 110*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackReaderImpl; 111*cc02d7e2SAndroid Build Coastguard Worker template <class Request> 112*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackWriterImpl; 113*cc02d7e2SAndroid Build Coastguard Worker class ClientCallbackUnaryImpl; 114*cc02d7e2SAndroid Build Coastguard Worker class ClientContextAccessor; 115*cc02d7e2SAndroid Build Coastguard Worker } // namespace internal 116*cc02d7e2SAndroid Build Coastguard Worker 117*cc02d7e2SAndroid Build Coastguard Worker class CallCredentials; 118*cc02d7e2SAndroid Build Coastguard Worker class Channel; 119*cc02d7e2SAndroid Build Coastguard Worker class ChannelInterface; 120*cc02d7e2SAndroid Build Coastguard Worker class CompletionQueue; 121*cc02d7e2SAndroid Build Coastguard Worker 122*cc02d7e2SAndroid Build Coastguard Worker /// Options for \a ClientContext::FromServerContext specifying which traits from 123*cc02d7e2SAndroid Build Coastguard Worker /// the \a ServerContext to propagate (copy) from it into a new \a 124*cc02d7e2SAndroid Build Coastguard Worker /// ClientContext. 125*cc02d7e2SAndroid Build Coastguard Worker /// 126*cc02d7e2SAndroid Build Coastguard Worker /// \see ClientContext::FromServerContext 127*cc02d7e2SAndroid Build Coastguard Worker class PropagationOptions { 128*cc02d7e2SAndroid Build Coastguard Worker public: PropagationOptions()129*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions() : propagate_(GRPC_PROPAGATE_DEFAULTS) {} 130*cc02d7e2SAndroid Build Coastguard Worker enable_deadline_propagation()131*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& enable_deadline_propagation() { 132*cc02d7e2SAndroid Build Coastguard Worker propagate_ |= GRPC_PROPAGATE_DEADLINE; 133*cc02d7e2SAndroid Build Coastguard Worker return *this; 134*cc02d7e2SAndroid Build Coastguard Worker } 135*cc02d7e2SAndroid Build Coastguard Worker disable_deadline_propagation()136*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& disable_deadline_propagation() { 137*cc02d7e2SAndroid Build Coastguard Worker propagate_ &= ~GRPC_PROPAGATE_DEADLINE; 138*cc02d7e2SAndroid Build Coastguard Worker return *this; 139*cc02d7e2SAndroid Build Coastguard Worker } 140*cc02d7e2SAndroid Build Coastguard Worker enable_census_stats_propagation()141*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& enable_census_stats_propagation() { 142*cc02d7e2SAndroid Build Coastguard Worker propagate_ |= GRPC_PROPAGATE_CENSUS_STATS_CONTEXT; 143*cc02d7e2SAndroid Build Coastguard Worker return *this; 144*cc02d7e2SAndroid Build Coastguard Worker } 145*cc02d7e2SAndroid Build Coastguard Worker disable_census_stats_propagation()146*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& disable_census_stats_propagation() { 147*cc02d7e2SAndroid Build Coastguard Worker propagate_ &= ~GRPC_PROPAGATE_CENSUS_STATS_CONTEXT; 148*cc02d7e2SAndroid Build Coastguard Worker return *this; 149*cc02d7e2SAndroid Build Coastguard Worker } 150*cc02d7e2SAndroid Build Coastguard Worker enable_census_tracing_propagation()151*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& enable_census_tracing_propagation() { 152*cc02d7e2SAndroid Build Coastguard Worker propagate_ |= GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT; 153*cc02d7e2SAndroid Build Coastguard Worker return *this; 154*cc02d7e2SAndroid Build Coastguard Worker } 155*cc02d7e2SAndroid Build Coastguard Worker disable_census_tracing_propagation()156*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& disable_census_tracing_propagation() { 157*cc02d7e2SAndroid Build Coastguard Worker propagate_ &= ~GRPC_PROPAGATE_CENSUS_TRACING_CONTEXT; 158*cc02d7e2SAndroid Build Coastguard Worker return *this; 159*cc02d7e2SAndroid Build Coastguard Worker } 160*cc02d7e2SAndroid Build Coastguard Worker enable_cancellation_propagation()161*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& enable_cancellation_propagation() { 162*cc02d7e2SAndroid Build Coastguard Worker propagate_ |= GRPC_PROPAGATE_CANCELLATION; 163*cc02d7e2SAndroid Build Coastguard Worker return *this; 164*cc02d7e2SAndroid Build Coastguard Worker } 165*cc02d7e2SAndroid Build Coastguard Worker disable_cancellation_propagation()166*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions& disable_cancellation_propagation() { 167*cc02d7e2SAndroid Build Coastguard Worker propagate_ &= ~GRPC_PROPAGATE_CANCELLATION; 168*cc02d7e2SAndroid Build Coastguard Worker return *this; 169*cc02d7e2SAndroid Build Coastguard Worker } 170*cc02d7e2SAndroid Build Coastguard Worker c_bitmask()171*cc02d7e2SAndroid Build Coastguard Worker uint32_t c_bitmask() const { return propagate_; } 172*cc02d7e2SAndroid Build Coastguard Worker 173*cc02d7e2SAndroid Build Coastguard Worker private: 174*cc02d7e2SAndroid Build Coastguard Worker uint32_t propagate_; 175*cc02d7e2SAndroid Build Coastguard Worker }; 176*cc02d7e2SAndroid Build Coastguard Worker 177*cc02d7e2SAndroid Build Coastguard Worker /// A ClientContext allows the person implementing a service client to: 178*cc02d7e2SAndroid Build Coastguard Worker /// 179*cc02d7e2SAndroid Build Coastguard Worker /// - Add custom metadata key-value pairs that will propagated to the server 180*cc02d7e2SAndroid Build Coastguard Worker /// side. 181*cc02d7e2SAndroid Build Coastguard Worker /// - Control call settings such as compression and authentication. 182*cc02d7e2SAndroid Build Coastguard Worker /// - Initial and trailing metadata coming from the server. 183*cc02d7e2SAndroid Build Coastguard Worker /// - Get performance metrics (ie, census). 184*cc02d7e2SAndroid Build Coastguard Worker /// 185*cc02d7e2SAndroid Build Coastguard Worker /// Context settings are only relevant to the call they are invoked with, that 186*cc02d7e2SAndroid Build Coastguard Worker /// is to say, they aren't sticky. Some of these settings, such as the 187*cc02d7e2SAndroid Build Coastguard Worker /// compression options, can be made persistent at channel construction time 188*cc02d7e2SAndroid Build Coastguard Worker /// (see \a grpc::CreateCustomChannel). 189*cc02d7e2SAndroid Build Coastguard Worker /// 190*cc02d7e2SAndroid Build Coastguard Worker /// \warning ClientContext instances should \em not be reused across rpcs. 191*cc02d7e2SAndroid Build Coastguard Worker /// \warning The ClientContext instance used for creating an rpc must remain 192*cc02d7e2SAndroid Build Coastguard Worker /// alive and valid for the lifetime of the rpc. 193*cc02d7e2SAndroid Build Coastguard Worker class ClientContext { 194*cc02d7e2SAndroid Build Coastguard Worker public: 195*cc02d7e2SAndroid Build Coastguard Worker ClientContext(); 196*cc02d7e2SAndroid Build Coastguard Worker ~ClientContext(); 197*cc02d7e2SAndroid Build Coastguard Worker 198*cc02d7e2SAndroid Build Coastguard Worker /// Create a new \a ClientContext as a child of an incoming server call, 199*cc02d7e2SAndroid Build Coastguard Worker /// according to \a options (\see PropagationOptions). 200*cc02d7e2SAndroid Build Coastguard Worker /// 201*cc02d7e2SAndroid Build Coastguard Worker /// \param server_context The source server context to use as the basis for 202*cc02d7e2SAndroid Build Coastguard Worker /// constructing the client context. 203*cc02d7e2SAndroid Build Coastguard Worker /// \param options The options controlling what to copy from the \a 204*cc02d7e2SAndroid Build Coastguard Worker /// server_context. 205*cc02d7e2SAndroid Build Coastguard Worker /// 206*cc02d7e2SAndroid Build Coastguard Worker /// \return A newly constructed \a ClientContext instance based on \a 207*cc02d7e2SAndroid Build Coastguard Worker /// server_context, with traits propagated (copied) according to \a options. 208*cc02d7e2SAndroid Build Coastguard Worker static std::unique_ptr<ClientContext> FromServerContext( 209*cc02d7e2SAndroid Build Coastguard Worker const grpc::ServerContextBase& server_context, 210*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions options = PropagationOptions()); 211*cc02d7e2SAndroid Build Coastguard Worker static std::unique_ptr<ClientContext> FromCallbackServerContext( 212*cc02d7e2SAndroid Build Coastguard Worker const grpc::CallbackServerContext& server_context, 213*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions options = PropagationOptions()); 214*cc02d7e2SAndroid Build Coastguard Worker 215*cc02d7e2SAndroid Build Coastguard Worker /// Add the (\a meta_key, \a meta_value) pair to the metadata associated with 216*cc02d7e2SAndroid Build Coastguard Worker /// a client call. These are made available at the server side by the \a 217*cc02d7e2SAndroid Build Coastguard Worker /// grpc::ServerContext::client_metadata() method. 218*cc02d7e2SAndroid Build Coastguard Worker /// 219*cc02d7e2SAndroid Build Coastguard Worker /// \warning This method should only be called before invoking the rpc. 220*cc02d7e2SAndroid Build Coastguard Worker /// 221*cc02d7e2SAndroid Build Coastguard Worker /// \param meta_key The metadata key. If \a meta_value is binary data, it must 222*cc02d7e2SAndroid Build Coastguard Worker /// end in "-bin". 223*cc02d7e2SAndroid Build Coastguard Worker /// \param meta_value The metadata value. If its value is binary, the key name 224*cc02d7e2SAndroid Build Coastguard Worker /// must end in "-bin". 225*cc02d7e2SAndroid Build Coastguard Worker /// 226*cc02d7e2SAndroid Build Coastguard Worker /// Metadata must conform to the following format: 227*cc02d7e2SAndroid Build Coastguard Worker /// 228*cc02d7e2SAndroid Build Coastguard Worker ///\verbatim 229*cc02d7e2SAndroid Build Coastguard Worker /// Custom-Metadata -> Binary-Header / ASCII-Header 230*cc02d7e2SAndroid Build Coastguard Worker /// Binary-Header -> {Header-Name "-bin" } {binary value} 231*cc02d7e2SAndroid Build Coastguard Worker /// ASCII-Header -> Header-Name ASCII-Value 232*cc02d7e2SAndroid Build Coastguard Worker /// Header-Name -> 1*( %x30-39 / %x61-7A / "_" / "-" / ".") ; 0-9 a-z _ - . 233*cc02d7e2SAndroid Build Coastguard Worker /// ASCII-Value -> 1*( %x20-%x7E ) ; space and printable ASCII 234*cc02d7e2SAndroid Build Coastguard Worker /// Custom-Metadata -> Binary-Header / ASCII-Header 235*cc02d7e2SAndroid Build Coastguard Worker ///\endverbatim 236*cc02d7e2SAndroid Build Coastguard Worker /// 237*cc02d7e2SAndroid Build Coastguard Worker void AddMetadata(const std::string& meta_key, const std::string& meta_value); 238*cc02d7e2SAndroid Build Coastguard Worker 239*cc02d7e2SAndroid Build Coastguard Worker /// Return a collection of initial metadata key-value pairs. Note that keys 240*cc02d7e2SAndroid Build Coastguard Worker /// may happen more than once (ie, a \a std::multimap is returned). 241*cc02d7e2SAndroid Build Coastguard Worker /// 242*cc02d7e2SAndroid Build Coastguard Worker /// \warning This method should only be called after initial metadata has been 243*cc02d7e2SAndroid Build Coastguard Worker /// received. For streaming calls, see \a 244*cc02d7e2SAndroid Build Coastguard Worker /// ClientReaderInterface::WaitForInitialMetadata(). 245*cc02d7e2SAndroid Build Coastguard Worker /// 246*cc02d7e2SAndroid Build Coastguard Worker /// \return A multimap of initial metadata key-value pairs from the server. 247*cc02d7e2SAndroid Build Coastguard Worker const std::multimap<grpc::string_ref, grpc::string_ref>& GetServerInitialMetadata()248*cc02d7e2SAndroid Build Coastguard Worker GetServerInitialMetadata() const { 249*cc02d7e2SAndroid Build Coastguard Worker GPR_ASSERT(initial_metadata_received_); 250*cc02d7e2SAndroid Build Coastguard Worker return *recv_initial_metadata_.map(); 251*cc02d7e2SAndroid Build Coastguard Worker } 252*cc02d7e2SAndroid Build Coastguard Worker 253*cc02d7e2SAndroid Build Coastguard Worker /// Return a collection of trailing metadata key-value pairs. Note that keys 254*cc02d7e2SAndroid Build Coastguard Worker /// may happen more than once (ie, a \a std::multimap is returned). 255*cc02d7e2SAndroid Build Coastguard Worker /// 256*cc02d7e2SAndroid Build Coastguard Worker /// \warning This method is only callable once the stream has finished. 257*cc02d7e2SAndroid Build Coastguard Worker /// 258*cc02d7e2SAndroid Build Coastguard Worker /// \return A multimap of metadata trailing key-value pairs from the server. 259*cc02d7e2SAndroid Build Coastguard Worker const std::multimap<grpc::string_ref, grpc::string_ref>& GetServerTrailingMetadata()260*cc02d7e2SAndroid Build Coastguard Worker GetServerTrailingMetadata() const { 261*cc02d7e2SAndroid Build Coastguard Worker // TODO(yangg) check finished 262*cc02d7e2SAndroid Build Coastguard Worker return *trailing_metadata_.map(); 263*cc02d7e2SAndroid Build Coastguard Worker } 264*cc02d7e2SAndroid Build Coastguard Worker 265*cc02d7e2SAndroid Build Coastguard Worker /// Set the deadline for the client call. 266*cc02d7e2SAndroid Build Coastguard Worker /// 267*cc02d7e2SAndroid Build Coastguard Worker /// \warning This method should only be called before invoking the rpc. 268*cc02d7e2SAndroid Build Coastguard Worker /// 269*cc02d7e2SAndroid Build Coastguard Worker /// \param deadline the deadline for the client call. Units are determined by 270*cc02d7e2SAndroid Build Coastguard Worker /// the type used. The deadline is an absolute (not relative) time. 271*cc02d7e2SAndroid Build Coastguard Worker template <typename T> set_deadline(const T & deadline)272*cc02d7e2SAndroid Build Coastguard Worker void set_deadline(const T& deadline) { 273*cc02d7e2SAndroid Build Coastguard Worker grpc::TimePoint<T> deadline_tp(deadline); 274*cc02d7e2SAndroid Build Coastguard Worker deadline_ = deadline_tp.raw_time(); 275*cc02d7e2SAndroid Build Coastguard Worker } 276*cc02d7e2SAndroid Build Coastguard Worker 277*cc02d7e2SAndroid Build Coastguard Worker /// Trigger wait-for-ready or not on this request. 278*cc02d7e2SAndroid Build Coastguard Worker /// See https://github.com/grpc/grpc/blob/master/doc/wait-for-ready.md. 279*cc02d7e2SAndroid Build Coastguard Worker /// If set, if an RPC is made when a channel's connectivity state is 280*cc02d7e2SAndroid Build Coastguard Worker /// TRANSIENT_FAILURE or CONNECTING, the call will not "fail fast", 281*cc02d7e2SAndroid Build Coastguard Worker /// and the channel will wait until the channel is READY before making the 282*cc02d7e2SAndroid Build Coastguard Worker /// call. set_wait_for_ready(bool wait_for_ready)283*cc02d7e2SAndroid Build Coastguard Worker void set_wait_for_ready(bool wait_for_ready) { 284*cc02d7e2SAndroid Build Coastguard Worker wait_for_ready_ = wait_for_ready; 285*cc02d7e2SAndroid Build Coastguard Worker wait_for_ready_explicitly_set_ = true; 286*cc02d7e2SAndroid Build Coastguard Worker } 287*cc02d7e2SAndroid Build Coastguard Worker 288*cc02d7e2SAndroid Build Coastguard Worker /// DEPRECATED: Use set_wait_for_ready() instead. set_fail_fast(bool fail_fast)289*cc02d7e2SAndroid Build Coastguard Worker void set_fail_fast(bool fail_fast) { set_wait_for_ready(!fail_fast); } 290*cc02d7e2SAndroid Build Coastguard Worker 291*cc02d7e2SAndroid Build Coastguard Worker /// Return the deadline for the client call. deadline()292*cc02d7e2SAndroid Build Coastguard Worker std::chrono::system_clock::time_point deadline() const { 293*cc02d7e2SAndroid Build Coastguard Worker return grpc::Timespec2Timepoint(deadline_); 294*cc02d7e2SAndroid Build Coastguard Worker } 295*cc02d7e2SAndroid Build Coastguard Worker 296*cc02d7e2SAndroid Build Coastguard Worker /// Return a \a gpr_timespec representation of the client call's deadline. raw_deadline()297*cc02d7e2SAndroid Build Coastguard Worker gpr_timespec raw_deadline() const { return deadline_; } 298*cc02d7e2SAndroid Build Coastguard Worker 299*cc02d7e2SAndroid Build Coastguard Worker /// Set the per call authority header (see 300*cc02d7e2SAndroid Build Coastguard Worker /// https://tools.ietf.org/html/rfc7540#section-8.1.2.3). set_authority(const std::string & authority)301*cc02d7e2SAndroid Build Coastguard Worker void set_authority(const std::string& authority) { authority_ = authority; } 302*cc02d7e2SAndroid Build Coastguard Worker 303*cc02d7e2SAndroid Build Coastguard Worker /// Return the authentication context for the associated client call. 304*cc02d7e2SAndroid Build Coastguard Worker /// It is only valid to call this during the lifetime of the client call. 305*cc02d7e2SAndroid Build Coastguard Worker /// 306*cc02d7e2SAndroid Build Coastguard Worker /// \see grpc::AuthContext. auth_context()307*cc02d7e2SAndroid Build Coastguard Worker std::shared_ptr<const grpc::AuthContext> auth_context() const { 308*cc02d7e2SAndroid Build Coastguard Worker if (auth_context_ == nullptr) { 309*cc02d7e2SAndroid Build Coastguard Worker auth_context_ = grpc::CreateAuthContext(call_); 310*cc02d7e2SAndroid Build Coastguard Worker } 311*cc02d7e2SAndroid Build Coastguard Worker return auth_context_; 312*cc02d7e2SAndroid Build Coastguard Worker } 313*cc02d7e2SAndroid Build Coastguard Worker 314*cc02d7e2SAndroid Build Coastguard Worker /// Set credentials for the client call. 315*cc02d7e2SAndroid Build Coastguard Worker /// 316*cc02d7e2SAndroid Build Coastguard Worker /// A credentials object encapsulates all the state needed by a client to 317*cc02d7e2SAndroid Build Coastguard Worker /// authenticate with a server and make various assertions, e.g., about the 318*cc02d7e2SAndroid Build Coastguard Worker /// client’s identity, role, or whether it is authorized to make a particular 319*cc02d7e2SAndroid Build Coastguard Worker /// call. 320*cc02d7e2SAndroid Build Coastguard Worker /// 321*cc02d7e2SAndroid Build Coastguard Worker /// It is legal to call this only before initial metadata is sent. 322*cc02d7e2SAndroid Build Coastguard Worker /// 323*cc02d7e2SAndroid Build Coastguard Worker /// \see https://grpc.io/docs/guides/auth.html 324*cc02d7e2SAndroid Build Coastguard Worker void set_credentials(const std::shared_ptr<grpc::CallCredentials>& creds); 325*cc02d7e2SAndroid Build Coastguard Worker 326*cc02d7e2SAndroid Build Coastguard Worker /// EXPERIMENTAL debugging API 327*cc02d7e2SAndroid Build Coastguard Worker /// 328*cc02d7e2SAndroid Build Coastguard Worker /// Returns the credentials for the client call. This should be used only in 329*cc02d7e2SAndroid Build Coastguard Worker /// tests and for diagnostic purposes, and should not be used by application 330*cc02d7e2SAndroid Build Coastguard Worker /// logic. credentials()331*cc02d7e2SAndroid Build Coastguard Worker std::shared_ptr<grpc::CallCredentials> credentials() { return creds_; } 332*cc02d7e2SAndroid Build Coastguard Worker 333*cc02d7e2SAndroid Build Coastguard Worker /// Return the compression algorithm the client call will request be used. 334*cc02d7e2SAndroid Build Coastguard Worker /// Note that the gRPC runtime may decide to ignore this request, for example, 335*cc02d7e2SAndroid Build Coastguard Worker /// due to resource constraints. compression_algorithm()336*cc02d7e2SAndroid Build Coastguard Worker grpc_compression_algorithm compression_algorithm() const { 337*cc02d7e2SAndroid Build Coastguard Worker return compression_algorithm_; 338*cc02d7e2SAndroid Build Coastguard Worker } 339*cc02d7e2SAndroid Build Coastguard Worker 340*cc02d7e2SAndroid Build Coastguard Worker /// Set \a algorithm to be the compression algorithm used for the client call. 341*cc02d7e2SAndroid Build Coastguard Worker /// 342*cc02d7e2SAndroid Build Coastguard Worker /// \param algorithm The compression algorithm used for the client call. 343*cc02d7e2SAndroid Build Coastguard Worker void set_compression_algorithm(grpc_compression_algorithm algorithm); 344*cc02d7e2SAndroid Build Coastguard Worker 345*cc02d7e2SAndroid Build Coastguard Worker /// Flag whether the initial metadata should be \a corked 346*cc02d7e2SAndroid Build Coastguard Worker /// 347*cc02d7e2SAndroid Build Coastguard Worker /// If \a corked is true, then the initial metadata will be coalesced with the 348*cc02d7e2SAndroid Build Coastguard Worker /// write of first message in the stream. As a result, any tag set for the 349*cc02d7e2SAndroid Build Coastguard Worker /// initial metadata operation (starting a client-streaming or bidi-streaming 350*cc02d7e2SAndroid Build Coastguard Worker /// RPC) will not actually be sent to the completion queue or delivered 351*cc02d7e2SAndroid Build Coastguard Worker /// via Next. 352*cc02d7e2SAndroid Build Coastguard Worker /// 353*cc02d7e2SAndroid Build Coastguard Worker /// \param corked The flag indicating whether the initial metadata is to be 354*cc02d7e2SAndroid Build Coastguard Worker /// corked or not. set_initial_metadata_corked(bool corked)355*cc02d7e2SAndroid Build Coastguard Worker void set_initial_metadata_corked(bool corked) { 356*cc02d7e2SAndroid Build Coastguard Worker initial_metadata_corked_ = corked; 357*cc02d7e2SAndroid Build Coastguard Worker } 358*cc02d7e2SAndroid Build Coastguard Worker 359*cc02d7e2SAndroid Build Coastguard Worker /// Return the peer uri in a string. 360*cc02d7e2SAndroid Build Coastguard Worker /// It is only valid to call this during the lifetime of the client call. 361*cc02d7e2SAndroid Build Coastguard Worker /// 362*cc02d7e2SAndroid Build Coastguard Worker /// \warning This value is never authenticated or subject to any security 363*cc02d7e2SAndroid Build Coastguard Worker /// related code. It must not be used for any authentication related 364*cc02d7e2SAndroid Build Coastguard Worker /// functionality. Instead, use auth_context. 365*cc02d7e2SAndroid Build Coastguard Worker /// 366*cc02d7e2SAndroid Build Coastguard Worker /// \return The call's peer URI. 367*cc02d7e2SAndroid Build Coastguard Worker std::string peer() const; 368*cc02d7e2SAndroid Build Coastguard Worker 369*cc02d7e2SAndroid Build Coastguard Worker /// Sets the census context. 370*cc02d7e2SAndroid Build Coastguard Worker /// It is only valid to call this before the client call is created. A common 371*cc02d7e2SAndroid Build Coastguard Worker /// place of setting census context is from within the DefaultConstructor 372*cc02d7e2SAndroid Build Coastguard Worker /// method of GlobalCallbacks. set_census_context(struct census_context * ccp)373*cc02d7e2SAndroid Build Coastguard Worker void set_census_context(struct census_context* ccp) { census_context_ = ccp; } 374*cc02d7e2SAndroid Build Coastguard Worker 375*cc02d7e2SAndroid Build Coastguard Worker /// Returns the census context that has been set, or nullptr if not set. census_context()376*cc02d7e2SAndroid Build Coastguard Worker struct census_context* census_context() const { return census_context_; } 377*cc02d7e2SAndroid Build Coastguard Worker 378*cc02d7e2SAndroid Build Coastguard Worker /// Send a best-effort out-of-band cancel on the call associated with 379*cc02d7e2SAndroid Build Coastguard Worker /// this client context. The call could be in any stage; e.g., if it is 380*cc02d7e2SAndroid Build Coastguard Worker /// already finished, it may still return success. 381*cc02d7e2SAndroid Build Coastguard Worker /// 382*cc02d7e2SAndroid Build Coastguard Worker /// There is no guarantee the call will be cancelled. 383*cc02d7e2SAndroid Build Coastguard Worker /// 384*cc02d7e2SAndroid Build Coastguard Worker /// Note that TryCancel() does not change any of the tags that are pending 385*cc02d7e2SAndroid Build Coastguard Worker /// on the completion queue. All pending tags will still be delivered 386*cc02d7e2SAndroid Build Coastguard Worker /// (though their ok result may reflect the effect of cancellation). 387*cc02d7e2SAndroid Build Coastguard Worker /// 388*cc02d7e2SAndroid Build Coastguard Worker /// This method is thread-safe, and can be called multiple times from any 389*cc02d7e2SAndroid Build Coastguard Worker /// thread. 390*cc02d7e2SAndroid Build Coastguard Worker void TryCancel(); 391*cc02d7e2SAndroid Build Coastguard Worker 392*cc02d7e2SAndroid Build Coastguard Worker /// Global Callbacks 393*cc02d7e2SAndroid Build Coastguard Worker /// 394*cc02d7e2SAndroid Build Coastguard Worker /// Can be set exactly once per application to install hooks whenever 395*cc02d7e2SAndroid Build Coastguard Worker /// a client context is constructed and destructed. 396*cc02d7e2SAndroid Build Coastguard Worker class GlobalCallbacks { 397*cc02d7e2SAndroid Build Coastguard Worker public: ~GlobalCallbacks()398*cc02d7e2SAndroid Build Coastguard Worker virtual ~GlobalCallbacks() {} 399*cc02d7e2SAndroid Build Coastguard Worker virtual void DefaultConstructor(ClientContext* context) = 0; 400*cc02d7e2SAndroid Build Coastguard Worker virtual void Destructor(ClientContext* context) = 0; 401*cc02d7e2SAndroid Build Coastguard Worker }; 402*cc02d7e2SAndroid Build Coastguard Worker static void SetGlobalCallbacks(GlobalCallbacks* callbacks); 403*cc02d7e2SAndroid Build Coastguard Worker 404*cc02d7e2SAndroid Build Coastguard Worker /// Should be used for framework-level extensions only. 405*cc02d7e2SAndroid Build Coastguard Worker /// Applications never need to call this method. c_call()406*cc02d7e2SAndroid Build Coastguard Worker grpc_call* c_call() { return call_; } 407*cc02d7e2SAndroid Build Coastguard Worker 408*cc02d7e2SAndroid Build Coastguard Worker /// EXPERIMENTAL debugging API 409*cc02d7e2SAndroid Build Coastguard Worker /// 410*cc02d7e2SAndroid Build Coastguard Worker /// if status is not ok() for an RPC, this will return a detailed string 411*cc02d7e2SAndroid Build Coastguard Worker /// of the gRPC Core error that led to the failure. It should not be relied 412*cc02d7e2SAndroid Build Coastguard Worker /// upon for anything other than gaining more debug data in failure cases. debug_error_string()413*cc02d7e2SAndroid Build Coastguard Worker std::string debug_error_string() const { return debug_error_string_; } 414*cc02d7e2SAndroid Build Coastguard Worker 415*cc02d7e2SAndroid Build Coastguard Worker private: 416*cc02d7e2SAndroid Build Coastguard Worker // Disallow copy and assign. 417*cc02d7e2SAndroid Build Coastguard Worker ClientContext(const ClientContext&); 418*cc02d7e2SAndroid Build Coastguard Worker ClientContext& operator=(const ClientContext&); 419*cc02d7e2SAndroid Build Coastguard Worker 420*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::testing::InteropClientContextInspector; 421*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::testing::ClientContextTestPeer; 422*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::CallOpClientRecvStatus; 423*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::CallOpRecvInitialMetadata; 424*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::Channel; 425*cc02d7e2SAndroid Build Coastguard Worker template <class R> 426*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientReader; 427*cc02d7e2SAndroid Build Coastguard Worker template <class W> 428*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientWriter; 429*cc02d7e2SAndroid Build Coastguard Worker template <class W, class R> 430*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientReaderWriter; 431*cc02d7e2SAndroid Build Coastguard Worker template <class R> 432*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientAsyncReader; 433*cc02d7e2SAndroid Build Coastguard Worker template <class W> 434*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientAsyncWriter; 435*cc02d7e2SAndroid Build Coastguard Worker template <class W, class R> 436*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientAsyncReaderWriter; 437*cc02d7e2SAndroid Build Coastguard Worker template <class R> 438*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::ClientAsyncResponseReader; 439*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::ClientAsyncResponseReaderHelper; 440*cc02d7e2SAndroid Build Coastguard Worker template <class InputMessage, class OutputMessage> 441*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::BlockingUnaryCallImpl; 442*cc02d7e2SAndroid Build Coastguard Worker template <class InputMessage, class OutputMessage> 443*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::CallbackUnaryCallImpl; 444*cc02d7e2SAndroid Build Coastguard Worker template <class Request, class Response> 445*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::ClientCallbackReaderWriterImpl; 446*cc02d7e2SAndroid Build Coastguard Worker template <class Response> 447*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::ClientCallbackReaderImpl; 448*cc02d7e2SAndroid Build Coastguard Worker template <class Request> 449*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::ClientCallbackWriterImpl; 450*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::ClientCallbackUnaryImpl; 451*cc02d7e2SAndroid Build Coastguard Worker friend class grpc::internal::ClientContextAccessor; 452*cc02d7e2SAndroid Build Coastguard Worker 453*cc02d7e2SAndroid Build Coastguard Worker // Used by friend class CallOpClientRecvStatus set_debug_error_string(const std::string & debug_error_string)454*cc02d7e2SAndroid Build Coastguard Worker void set_debug_error_string(const std::string& debug_error_string) { 455*cc02d7e2SAndroid Build Coastguard Worker debug_error_string_ = debug_error_string; 456*cc02d7e2SAndroid Build Coastguard Worker } 457*cc02d7e2SAndroid Build Coastguard Worker call()458*cc02d7e2SAndroid Build Coastguard Worker grpc_call* call() const { return call_; } 459*cc02d7e2SAndroid Build Coastguard Worker void set_call(grpc_call* call, const std::shared_ptr<grpc::Channel>& channel); 460*cc02d7e2SAndroid Build Coastguard Worker set_client_rpc_info(const char * method,const char * suffix_for_stats,grpc::internal::RpcMethod::RpcType type,grpc::ChannelInterface * channel,const std::vector<std::unique_ptr<grpc::experimental::ClientInterceptorFactoryInterface>> & creators,size_t interceptor_pos)461*cc02d7e2SAndroid Build Coastguard Worker grpc::experimental::ClientRpcInfo* set_client_rpc_info( 462*cc02d7e2SAndroid Build Coastguard Worker const char* method, const char* suffix_for_stats, 463*cc02d7e2SAndroid Build Coastguard Worker grpc::internal::RpcMethod::RpcType type, grpc::ChannelInterface* channel, 464*cc02d7e2SAndroid Build Coastguard Worker const std::vector<std::unique_ptr< 465*cc02d7e2SAndroid Build Coastguard Worker grpc::experimental::ClientInterceptorFactoryInterface>>& creators, 466*cc02d7e2SAndroid Build Coastguard Worker size_t interceptor_pos) { 467*cc02d7e2SAndroid Build Coastguard Worker rpc_info_ = grpc::experimental::ClientRpcInfo(this, type, method, 468*cc02d7e2SAndroid Build Coastguard Worker suffix_for_stats, channel); 469*cc02d7e2SAndroid Build Coastguard Worker rpc_info_.RegisterInterceptors(creators, interceptor_pos); 470*cc02d7e2SAndroid Build Coastguard Worker return &rpc_info_; 471*cc02d7e2SAndroid Build Coastguard Worker } 472*cc02d7e2SAndroid Build Coastguard Worker initial_metadata_flags()473*cc02d7e2SAndroid Build Coastguard Worker uint32_t initial_metadata_flags() const { 474*cc02d7e2SAndroid Build Coastguard Worker return (wait_for_ready_ ? GRPC_INITIAL_METADATA_WAIT_FOR_READY : 0) | 475*cc02d7e2SAndroid Build Coastguard Worker (wait_for_ready_explicitly_set_ 476*cc02d7e2SAndroid Build Coastguard Worker ? GRPC_INITIAL_METADATA_WAIT_FOR_READY_EXPLICITLY_SET 477*cc02d7e2SAndroid Build Coastguard Worker : 0); 478*cc02d7e2SAndroid Build Coastguard Worker } 479*cc02d7e2SAndroid Build Coastguard Worker authority()480*cc02d7e2SAndroid Build Coastguard Worker std::string authority() { return authority_; } 481*cc02d7e2SAndroid Build Coastguard Worker 482*cc02d7e2SAndroid Build Coastguard Worker void SendCancelToInterceptors(); 483*cc02d7e2SAndroid Build Coastguard Worker 484*cc02d7e2SAndroid Build Coastguard Worker static std::unique_ptr<ClientContext> FromInternalServerContext( 485*cc02d7e2SAndroid Build Coastguard Worker const grpc::ServerContextBase& server_context, 486*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions options); 487*cc02d7e2SAndroid Build Coastguard Worker 488*cc02d7e2SAndroid Build Coastguard Worker bool initial_metadata_received_; 489*cc02d7e2SAndroid Build Coastguard Worker bool wait_for_ready_; 490*cc02d7e2SAndroid Build Coastguard Worker bool wait_for_ready_explicitly_set_; 491*cc02d7e2SAndroid Build Coastguard Worker std::shared_ptr<grpc::Channel> channel_; 492*cc02d7e2SAndroid Build Coastguard Worker grpc::internal::Mutex mu_; 493*cc02d7e2SAndroid Build Coastguard Worker grpc_call* call_; 494*cc02d7e2SAndroid Build Coastguard Worker bool call_canceled_; 495*cc02d7e2SAndroid Build Coastguard Worker gpr_timespec deadline_; 496*cc02d7e2SAndroid Build Coastguard Worker grpc::string authority_; 497*cc02d7e2SAndroid Build Coastguard Worker std::shared_ptr<grpc::CallCredentials> creds_; 498*cc02d7e2SAndroid Build Coastguard Worker mutable std::shared_ptr<const grpc::AuthContext> auth_context_; 499*cc02d7e2SAndroid Build Coastguard Worker struct census_context* census_context_; 500*cc02d7e2SAndroid Build Coastguard Worker std::multimap<std::string, std::string> send_initial_metadata_; 501*cc02d7e2SAndroid Build Coastguard Worker mutable grpc::internal::MetadataMap recv_initial_metadata_; 502*cc02d7e2SAndroid Build Coastguard Worker mutable grpc::internal::MetadataMap trailing_metadata_; 503*cc02d7e2SAndroid Build Coastguard Worker 504*cc02d7e2SAndroid Build Coastguard Worker grpc_call* propagate_from_call_; 505*cc02d7e2SAndroid Build Coastguard Worker PropagationOptions propagation_options_; 506*cc02d7e2SAndroid Build Coastguard Worker 507*cc02d7e2SAndroid Build Coastguard Worker grpc_compression_algorithm compression_algorithm_; 508*cc02d7e2SAndroid Build Coastguard Worker bool initial_metadata_corked_; 509*cc02d7e2SAndroid Build Coastguard Worker 510*cc02d7e2SAndroid Build Coastguard Worker std::string debug_error_string_; 511*cc02d7e2SAndroid Build Coastguard Worker 512*cc02d7e2SAndroid Build Coastguard Worker grpc::experimental::ClientRpcInfo rpc_info_; 513*cc02d7e2SAndroid Build Coastguard Worker }; 514*cc02d7e2SAndroid Build Coastguard Worker 515*cc02d7e2SAndroid Build Coastguard Worker } // namespace grpc 516*cc02d7e2SAndroid Build Coastguard Worker 517*cc02d7e2SAndroid Build Coastguard Worker #endif // GRPCPP_CLIENT_CONTEXT_H 518