19 #ifndef GRPCPP_IMPL_CODEGEN_SERVER_INTERFACE_H 20 #define GRPCPP_IMPL_CODEGEN_SERVER_INTERFACE_H 40 class AsyncGenericService;
41 class GenericServerContext;
50 class ServerAsyncStreamingInterface;
53 namespace experimental {
54 class CallbackGenericService;
112 virtual void Wait() = 0;
115 friend class ::grpc::Service;
167 virtual void ShutdownInternal(
gpr_timespec deadline) = 0;
169 virtual int max_receive_message_size()
const = 0;
183 void* tag,
bool delete_on_finalize);
186 bool FinalizeResult(
void** tag,
bool* status)
override;
189 void ContinueFinalizeResultAfterInterception();
213 void* tag,
const char* name,
218 if (done_intercepting_) {
219 return BaseAsyncRequest::FinalizeResult(tag, status);
222 call_, server_, call_cq_, server_->max_receive_message_size(),
223 context_->set_server_rpc_info(name_, type_,
224 *server_->interceptor_creators()));
225 return BaseAsyncRequest::FinalizeResult(tag, status);
245 server, context, stream, call_cq, notification_cq, tag,
246 registered_method->name(), registered_method->method_type()) {
247 IssueRequest(registered_method->
server_tag(),
nullptr, notification_cq);
253 template <
class Message>
264 server, context, stream, call_cq, notification_cq, tag,
265 registered_method->name(), registered_method->method_type()),
266 registered_method_(registered_method),
271 notification_cq_(notification_cq),
274 IssueRequest(registered_method->
server_tag(), payload_.bbuf_ptr(),
284 if (done_intercepting_) {
285 return RegisteredAsyncRequest::FinalizeResult(tag, status);
289 payload_.bbuf_ptr(), request_)
295 g_core_codegen_interface->grpc_call_cancel_with_status(
297 g_core_codegen_interface->grpc_call_unref(call_);
299 stream_, call_cq_, notification_cq_, tag_,
306 interceptor_methods_.AddInterceptionHookPoint(
307 experimental::InterceptionHookPoints::POST_RECV_MESSAGE);
308 interceptor_methods_.SetRecvMessage(request_,
nullptr);
309 return RegisteredAsyncRequest::FinalizeResult(tag, status);
331 void* tag,
bool delete_on_finalize);
333 bool FinalizeResult(
void** tag,
bool* status)
override;
339 template <
class Message>
348 notification_cq, tag, message);
359 notification_cq, tag);
378 std::unique_ptr<experimental::ServerInterceptorFactoryInterface>>*
379 interceptor_creators() {
396 #endif // GRPCPP_IMPL_CODEGEN_SERVER_INTERFACE_H ::grpc_impl::ServerCompletionQueue *const notification_cq_
Definition: server_interface.h:196
struct grpc_call grpc_call
A Call represents an RPC.
Definition: grpc_types.h:70
virtual ~ServerInterface()
Definition: server_interface.h:59
Definition: server_interface.h:235
PayloadAsyncRequest(internal::RpcServiceMethod *registered_method, ServerInterface *server, ::grpc_impl::ServerContext *context, internal::ServerAsyncStreamingInterface *stream, ::grpc_impl::CompletionQueue *call_cq, ::grpc_impl::ServerCompletionQueue *notification_cq, void *tag, Message *request)
Definition: server_interface.h:256
#define GPR_CODEGEN_ASSERT(x)
Codegen specific version of GPR_ASSERT.
Definition: core_codegen_interface.h:145
void Shutdown()
Shutdown the server without a deadline and forced cancellation.
Definition: server_interface.h:103
std::string string
Definition: config.h:35
const internal::RpcMethod::RpcType type_
Definition: server_interface.h:232
An interface allowing implementors to process and filter event tags.
Definition: completion_queue_tag.h:26
NOTE: class experimental_registration_interface is not part of the public API of this class TODO(vjpa...
Definition: server_interface.h:128
::grpc_impl::ServerCredentials ServerCredentials
Definition: server_credentials.h:30
void * server_tag() const
Definition: rpc_service_method.h:106
Definition: server_interface.h:254
ServerInterface *const server_
Definition: server_interface.h:192
Desriptor of an RPC service and its various RPC methods.
Definition: service_type.h:60
RegisteredAsyncRequest is not part of the C++ API.
Definition: server_interface.h:206
internal::InterceptorBatchMethodsImpl interceptor_methods_
Definition: server_interface.h:201
bool done_intercepting_
Definition: server_interface.h:202
Monotonic clock.
Definition: gpr_types.h:33
struct grpc_server grpc_server
A server listens to some port and responds to request calls.
Definition: grpc_types.h:65
Definition: service_type.h:41
Definition: grpc_types.h:519
Definition: grpc_types.h:40
Definition: async_generic_service.h:74
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
::grpc_impl::CompletionQueue *const call_cq_
Definition: server_interface.h:195
A ServerContext allows the person implementing a service handler to:
Definition: server_context_impl.h:118
virtual ~experimental_registration_interface()
Definition: server_interface.h:130
virtual void RegisterCallbackGenericService(experimental::CallbackGenericService *service)
May not be abstract since this is a post-1.0 API addition.
Definition: server_interface.h:132
Defines how to serialize and deserialize some type.
Definition: serialization_traits.h:58
::grpc_impl::ServerCompletionQueue ServerCompletionQueue
Definition: completion_queue.h:27
internal::Call call_wrapper_
Definition: server_interface.h:200
::grpc_impl::Channel Channel
Definition: channel.h:26
::grpc_impl::CompletionQueue CompletionQueue
Definition: completion_queue.h:26
::grpc_impl::ServerContext *const context_
Definition: server_interface.h:193
internal::ServerAsyncStreamingInterface *const stream_
Definition: server_interface.h:194
This header provides an object that reads bytes directly from a grpc::ByteBuffer, via the ZeroCopyInp...
Definition: alarm.h:24
const bool delete_on_finalize_
Definition: server_interface.h:198
Server side rpc method class.
Definition: rpc_service_method.h:87
CoreCodegenInterface * g_core_codegen_interface
Definition: completion_queue_impl.h:91
Definition: interceptor_common.h:36
Definition: server_interface.h:57
grpc_call * call_
Definition: server_interface.h:199
const char * name_
Definition: server_interface.h:231
Definition: async_generic_service.h:38
An Alarm posts the user-provided tag to its associated completion queue or invokes the user-provided ...
Definition: alarm_impl.h:33
CallbackGenericService is the base class for generic services implemented using the callback API and ...
Definition: async_generic_service.h:129
bool FinalizeResult(void **tag, bool *status) override
FinalizeResult must be called before informing user code that the operation bound to the underlying c...
Definition: server_interface.h:282
void RequestAsyncCall(internal::RpcServiceMethod *method, ::grpc_impl::ServerContext *context, internal::ServerAsyncStreamingInterface *stream, ::grpc_impl::CompletionQueue *call_cq, ::grpc_impl::ServerCompletionQueue *notification_cq, void *tag, Message *message)
Definition: server_interface.h:340
Wrapper around grpc_server_credentials, a way to authenticate a server.
Definition: server_credentials_impl.h:39
void RequestAsyncGenericCall(GenericServerContext *context, internal::ServerAsyncStreamingInterface *stream, ::grpc_impl::CompletionQueue *call_cq, ::grpc_impl::ServerCompletionQueue *notification_cq, void *tag)
Definition: server_interface.h:362
void Shutdown(const T &deadline)
Shutdown does the following things:
Definition: server_interface.h:94
An abstract collection of call ops, used to generate the grpc_call_op structure to pass down to the l...
Definition: call_op_set_interface.h:34
~PayloadAsyncRequest()
Definition: server_interface.h:278
A thin wrapper around grpc_completion_queue (see src/core/lib/surface/completion_queue.h).
Definition: completion_queue_impl.h:101
Internal errors.
Definition: status.h:127
virtual experimental_registration_interface * experimental_registration()
NOTE: The function experimental_registration() is not stable public API.
Definition: server_interface.h:140
Analogous to struct timespec.
Definition: gpr_types.h:47
Definition: server_interface.h:325
void *const tag_
Definition: server_interface.h:197
A specific type of completion queue used by the processing of notifications by servers.
Definition: completion_queue_impl.h:390
NoPayloadAsyncRequest(internal::RpcServiceMethod *registered_method, ServerInterface *server, ::grpc_impl::ServerContext *context, internal::ServerAsyncStreamingInterface *stream, ::grpc_impl::CompletionQueue *call_cq, ::grpc_impl::ServerCompletionQueue *notification_cq, void *tag)
Definition: server_interface.h:237
This is an interface that Channel and Server implement to allow them to hook performing ops...
Definition: call_hook.h:30
A sequence of bytes.
Definition: byte_buffer.h:72
Definition: server_interface.h:176
virtual bool FinalizeResult(void **tag, bool *status) override
FinalizeResult must be called before informing user code that the operation bound to the underlying c...
Definition: server_interface.h:216
void RequestAsyncCall(internal::RpcServiceMethod *method, ::grpc_impl::ServerContext *context, internal::ServerAsyncStreamingInterface *stream, ::grpc_impl::CompletionQueue *call_cq, ::grpc_impl::ServerCompletionQueue *notification_cq, void *tag)
Definition: server_interface.h:351
Straightforward wrapping of the C call object.
Definition: call.h:38
::google::protobuf::Message Message
Definition: config_protobuf.h:80