34 #ifndef GRPCXX_IMPL_CODEGEN_SERVER_INTERFACE_H 35 #define GRPCXX_IMPL_CODEGEN_SERVER_INTERFACE_H 45 class AsyncGenericService;
46 class GenericServerContext;
48 class ServerAsyncStreamingInterface;
49 class ServerCompletionQueue;
51 class ServerCredentials;
53 class ThreadPoolInterface;
87 virtual void Wait() = 0;
125 virtual void RunRpc() = 0;
143 bool delete_on_finalize);
180 IssueRequest(registered_method,
nullptr, notification_cq);
186 template <
class Message>
197 IssueRequest(registered_method, &payload_, notification_cq);
201 bool serialization_status =
202 *status && payload_ &&
207 *status = serialization_status && *status;
213 Message*
const request_;
222 bool delete_on_finalize);
230 template <
class Message>
238 stream, call_cq, notification_cq, tag,
248 call_cq, notification_cq, tag);
263 #endif // GRPCXX_IMPL_CODEGEN_SERVER_INTERFACE_H struct grpc_call grpc_call
A Call represents an RPC.
Definition: grpc_types.h:62
PayloadAsyncRequest(void *registered_method, ServerInterface *server, ServerContext *context, ServerAsyncStreamingInterface *stream, CompletionQueue *call_cq, ServerCompletionQueue *notification_cq, void *tag, Message *request)
Definition: server_interface.h:189
virtual ~ServerInterface()
Definition: server_interface.h:60
An interface allowing implementors to process and filter event tags.
Definition: completion_queue_tag.h:40
Definition: server_interface.h:172
void Shutdown()
Shutdown the server, waiting for all rpc processing to finish.
Definition: server_interface.h:81
bool FinalizeResult(void **tag, bool *status) GRPC_OVERRIDE
std::string string
Definition: config.h:118
An abstract collection of call ops, used to generate the grpc_call_op structure to pass down to the l...
Definition: call.h:563
#define GPR_CODEGEN_ASSERT(x)
Codegen specific version of GPR_ASSERT.
Definition: core_codegen_interface.h:97
Definition: server_interface.h:187
ServerInterface *const server_
Definition: server_interface.h:149
Definition: service_type.h:64
virtual void ShutdownInternal(gpr_timespec deadline)=0
Definition: server_interface.h:159
Definition: service_type.h:53
struct grpc_server grpc_server
A server listens to some port and responds to request calls.
Definition: grpc_types.h:57
Definition: grpc_types.h:275
Definition: byte_buffer.h:49
Definition: async_generic_service.h:60
virtual void RunRpc()=0
Process one or more incoming calls.
virtual ~BaseAsyncRequest()
Definition: server_interface.h:144
Definition: rpc_service_method.h:73
void RequestAsyncCall(RpcServiceMethod *method, ServerContext *context, ServerAsyncStreamingInterface *stream, CompletionQueue *call_cq, ServerCompletionQueue *notification_cq, void *tag)
Definition: server_interface.h:242
Defines how to serialize and deserialize some type.
Definition: serialization_traits.h:64
virtual grpc_server * server()=0
Definition: server_credentials.h:50
virtual void PerformOpsOnCall(CallOpSetInterface *ops, Call *call)=0
const bool delete_on_finalize_
Definition: server_interface.h:154
grpc_metadata_array initial_metadata_array_
Definition: server_interface.h:156
bool FinalizeResult(void **tag, bool *status) GRPC_OVERRIDE
Definition: server_interface.h:200
Definition: server_context.h:91
Models a gRPC server.
Definition: server_interface.h:58
grpc_call * call_
Definition: server_interface.h:155
CompletionQueue *const call_cq_
Definition: server_interface.h:152
virtual bool RegisterService(const grpc::string *host, Service *service)=0
Register a service.
ServerAsyncStreamingInterface *const stream_
Definition: server_interface.h:151
Definition: async_generic_service.h:47
A thin wrapper around grpc_completion_queue (see / src/core/surface/completion_queue.h).
Definition: completion_queue.h:97
#define GRPC_FINAL
Definition: config.h:72
virtual int max_message_size() const =0
void Shutdown(const T &deadline)
Shutdown the server, blocking until all rpc processing finishes.
Definition: server_interface.h:72
BaseAsyncRequest(ServerInterface *server, ServerContext *context, ServerAsyncStreamingInterface *stream, CompletionQueue *call_cq, void *tag, bool delete_on_finalize)
virtual void ScheduleCallback()=0
Schedule RunRpc to run in the threadpool.
ServerContext *const context_
Definition: server_interface.h:150
virtual void RegisterAsyncGenericService(AsyncGenericService *service)=0
Register a generic service.
virtual int AddListeningPort(const grpc::string &addr, ServerCredentials *creds)=0
Tries to bind server to the given addr.
GPRAPI gpr_timespec gpr_inf_future(gpr_clock_type type)
void * server_tag() const
Definition: rpc_service_method.h:81
Definition: server_interface.h:216
void RequestAsyncGenericCall(GenericServerContext *context, ServerAsyncStreamingInterface *stream, CompletionQueue *call_cq, ServerCompletionQueue *notification_cq, void *tag)
Definition: server_interface.h:251
void *const tag_
Definition: server_interface.h:153
virtual void Wait()=0
Block waiting for all work to complete.
A specific type of completion queue used by the processing of notifications by servers.
Definition: completion_queue.h:235
NoPayloadAsyncRequest(void *registered_method, ServerInterface *server, ServerContext *context, ServerAsyncStreamingInterface *stream, CompletionQueue *call_cq, ServerCompletionQueue *notification_cq, void *tag)
Definition: server_interface.h:174
Channel and Server implement this to allow them to hook performing ops.
Definition: call_hook.h:43
#define GRPC_OVERRIDE
Definition: config.h:78
Definition: server_interface.h:138
void RequestAsyncCall(RpcServiceMethod *method, ServerContext *context, ServerAsyncStreamingInterface *stream, CompletionQueue *call_cq, ServerCompletionQueue *notification_cq, void *tag, Message *message)
Definition: server_interface.h:231
virtual bool Start(ServerCompletionQueue **cqs, size_t num_cqs)=0
Start the server.