[generic API] separate callback from cq in generic stub/service (#36447)

See https://github.com/grpc/proposal/pull/426

<!--

If you know who should review your pull request, please assign it to that
person, otherwise the pull request would get assigned randomly.

If your pull request is for a specific language, please add the appropriate
lang label.

-->

Closes #36447

COPYBARA_INTEGRATE_REVIEW=https://github.com/grpc/grpc/pull/36447 from yousukseung:generic-stub-service-refactor 1cc0cbdc4b
PiperOrigin-RevId: 642774012
pull/36817/head^2
Yousuk Seung 6 months ago committed by Copybara-Service
parent f7ce3ee9d5
commit 568fbfff8c
  1. 40
      BUILD
  2. 6
      CMakeLists.txt
  3. 6
      build_autogenerated.yaml
  4. 3
      gRPC-C++.podspec
  5. 54
      include/grpcpp/generic/async_generic_service.h
  6. 84
      include/grpcpp/generic/callback_generic_service.h
  7. 83
      include/grpcpp/generic/generic_stub.h
  8. 44
      include/grpcpp/generic/generic_stub_callback.h
  9. 125
      include/grpcpp/impl/generic_stub_internal.h
  10. 3
      tools/doxygen/Doxyfile.c++
  11. 3
      tools/doxygen/Doxyfile.c++.internal

40
BUILD

@ -415,7 +415,9 @@ GRPCXX_PUBLIC_HDRS = [
"include/grpcpp/create_channel_posix.h", "include/grpcpp/create_channel_posix.h",
"include/grpcpp/ext/health_check_service_server_builder_option.h", "include/grpcpp/ext/health_check_service_server_builder_option.h",
"include/grpcpp/generic/async_generic_service.h", "include/grpcpp/generic/async_generic_service.h",
"include/grpcpp/generic/callback_generic_service.h",
"include/grpcpp/generic/generic_stub.h", "include/grpcpp/generic/generic_stub.h",
"include/grpcpp/generic/generic_stub_callback.h",
"include/grpcpp/grpcpp.h", "include/grpcpp/grpcpp.h",
"include/grpcpp/health_check_service_interface.h", "include/grpcpp/health_check_service_interface.h",
"include/grpcpp/impl/call_hook.h", "include/grpcpp/impl/call_hook.h",
@ -1260,6 +1262,7 @@ grpc_cc_library(
visibility = ["@grpc:public"], visibility = ["@grpc:public"],
deps = [ deps = [
"channel_arg_names", "channel_arg_names",
"generic_stub_internal",
"gpr", "gpr",
"grpc++_base_unsecure", "grpc++_base_unsecure",
"grpc++_codegen_proto", "grpc++_codegen_proto",
@ -2470,6 +2473,7 @@ grpc_cc_library(
"channel_stack_builder", "channel_stack_builder",
"config", "config",
"exec_ctx", "exec_ctx",
"generic_stub_internal",
"gpr", "gpr",
"grpc", "grpc",
"grpc++_codegen_proto", "grpc++_codegen_proto",
@ -2558,6 +2562,7 @@ grpc_cc_library(
"channel_stack_builder", "channel_stack_builder",
"config", "config",
"exec_ctx", "exec_ctx",
"generic_stub_internal",
"gpr", "gpr",
"grpc_base", "grpc_base",
"grpc_core_credentials_header", "grpc_core_credentials_header",
@ -2955,6 +2960,41 @@ grpc_cc_library(
], ],
) )
grpc_cc_library(
name = "generic_stub_internal",
hdrs = [
"include/grpcpp/impl/generic_stub_internal.h",
],
language = "c++",
deps = [
"grpc++_public_hdrs",
],
)
grpc_cc_library(
name = "generic_stub_callback",
hdrs = [
"include/grpcpp/generic/generic_stub_callback.h",
],
language = "c++",
visibility = ["@grpc:public"],
deps = [
"generic_stub_internal",
],
)
grpc_cc_library(
name = "callback_generic_service",
hdrs = [
"include/grpcpp/generic/callback_generic_service.h",
],
language = "c++",
visibility = ["@grpc:public"],
deps = [
"grpc++_public_hdrs",
],
)
grpc_cc_library( grpc_cc_library(
name = "work_serializer", name = "work_serializer",
srcs = [ srcs = [

6
CMakeLists.txt generated

@ -4253,7 +4253,9 @@ foreach(_hdr
include/grpcpp/ext/health_check_service_server_builder_option.h include/grpcpp/ext/health_check_service_server_builder_option.h
include/grpcpp/ext/server_metric_recorder.h include/grpcpp/ext/server_metric_recorder.h
include/grpcpp/generic/async_generic_service.h include/grpcpp/generic/async_generic_service.h
include/grpcpp/generic/callback_generic_service.h
include/grpcpp/generic/generic_stub.h include/grpcpp/generic/generic_stub.h
include/grpcpp/generic/generic_stub_callback.h
include/grpcpp/grpcpp.h include/grpcpp/grpcpp.h
include/grpcpp/health_check_service_interface.h include/grpcpp/health_check_service_interface.h
include/grpcpp/impl/call.h include/grpcpp/impl/call.h
@ -4314,6 +4316,7 @@ foreach(_hdr
include/grpcpp/impl/completion_queue_tag.h include/grpcpp/impl/completion_queue_tag.h
include/grpcpp/impl/create_auth_context.h include/grpcpp/impl/create_auth_context.h
include/grpcpp/impl/delegating_channel.h include/grpcpp/impl/delegating_channel.h
include/grpcpp/impl/generic_stub_internal.h
include/grpcpp/impl/grpc_library.h include/grpcpp/impl/grpc_library.h
include/grpcpp/impl/intercepted_channel.h include/grpcpp/impl/intercepted_channel.h
include/grpcpp/impl/interceptor_common.h include/grpcpp/impl/interceptor_common.h
@ -4996,7 +4999,9 @@ foreach(_hdr
include/grpcpp/ext/health_check_service_server_builder_option.h include/grpcpp/ext/health_check_service_server_builder_option.h
include/grpcpp/ext/server_metric_recorder.h include/grpcpp/ext/server_metric_recorder.h
include/grpcpp/generic/async_generic_service.h include/grpcpp/generic/async_generic_service.h
include/grpcpp/generic/callback_generic_service.h
include/grpcpp/generic/generic_stub.h include/grpcpp/generic/generic_stub.h
include/grpcpp/generic/generic_stub_callback.h
include/grpcpp/grpcpp.h include/grpcpp/grpcpp.h
include/grpcpp/health_check_service_interface.h include/grpcpp/health_check_service_interface.h
include/grpcpp/impl/call.h include/grpcpp/impl/call.h
@ -5057,6 +5062,7 @@ foreach(_hdr
include/grpcpp/impl/completion_queue_tag.h include/grpcpp/impl/completion_queue_tag.h
include/grpcpp/impl/create_auth_context.h include/grpcpp/impl/create_auth_context.h
include/grpcpp/impl/delegating_channel.h include/grpcpp/impl/delegating_channel.h
include/grpcpp/impl/generic_stub_internal.h
include/grpcpp/impl/grpc_library.h include/grpcpp/impl/grpc_library.h
include/grpcpp/impl/intercepted_channel.h include/grpcpp/impl/intercepted_channel.h
include/grpcpp/impl/interceptor_common.h include/grpcpp/impl/interceptor_common.h

@ -3713,7 +3713,9 @@ libs:
- include/grpcpp/ext/health_check_service_server_builder_option.h - include/grpcpp/ext/health_check_service_server_builder_option.h
- include/grpcpp/ext/server_metric_recorder.h - include/grpcpp/ext/server_metric_recorder.h
- include/grpcpp/generic/async_generic_service.h - include/grpcpp/generic/async_generic_service.h
- include/grpcpp/generic/callback_generic_service.h
- include/grpcpp/generic/generic_stub.h - include/grpcpp/generic/generic_stub.h
- include/grpcpp/generic/generic_stub_callback.h
- include/grpcpp/grpcpp.h - include/grpcpp/grpcpp.h
- include/grpcpp/health_check_service_interface.h - include/grpcpp/health_check_service_interface.h
- include/grpcpp/impl/call.h - include/grpcpp/impl/call.h
@ -3774,6 +3776,7 @@ libs:
- include/grpcpp/impl/completion_queue_tag.h - include/grpcpp/impl/completion_queue_tag.h
- include/grpcpp/impl/create_auth_context.h - include/grpcpp/impl/create_auth_context.h
- include/grpcpp/impl/delegating_channel.h - include/grpcpp/impl/delegating_channel.h
- include/grpcpp/impl/generic_stub_internal.h
- include/grpcpp/impl/grpc_library.h - include/grpcpp/impl/grpc_library.h
- include/grpcpp/impl/intercepted_channel.h - include/grpcpp/impl/intercepted_channel.h
- include/grpcpp/impl/interceptor_common.h - include/grpcpp/impl/interceptor_common.h
@ -4143,7 +4146,9 @@ libs:
- include/grpcpp/ext/health_check_service_server_builder_option.h - include/grpcpp/ext/health_check_service_server_builder_option.h
- include/grpcpp/ext/server_metric_recorder.h - include/grpcpp/ext/server_metric_recorder.h
- include/grpcpp/generic/async_generic_service.h - include/grpcpp/generic/async_generic_service.h
- include/grpcpp/generic/callback_generic_service.h
- include/grpcpp/generic/generic_stub.h - include/grpcpp/generic/generic_stub.h
- include/grpcpp/generic/generic_stub_callback.h
- include/grpcpp/grpcpp.h - include/grpcpp/grpcpp.h
- include/grpcpp/health_check_service_interface.h - include/grpcpp/health_check_service_interface.h
- include/grpcpp/impl/call.h - include/grpcpp/impl/call.h
@ -4204,6 +4209,7 @@ libs:
- include/grpcpp/impl/completion_queue_tag.h - include/grpcpp/impl/completion_queue_tag.h
- include/grpcpp/impl/create_auth_context.h - include/grpcpp/impl/create_auth_context.h
- include/grpcpp/impl/delegating_channel.h - include/grpcpp/impl/delegating_channel.h
- include/grpcpp/impl/generic_stub_internal.h
- include/grpcpp/impl/grpc_library.h - include/grpcpp/impl/grpc_library.h
- include/grpcpp/impl/intercepted_channel.h - include/grpcpp/impl/intercepted_channel.h
- include/grpcpp/impl/interceptor_common.h - include/grpcpp/impl/interceptor_common.h

3
gRPC-C++.podspec generated

@ -103,7 +103,9 @@ Pod::Spec.new do |s|
'include/grpcpp/ext/health_check_service_server_builder_option.h', 'include/grpcpp/ext/health_check_service_server_builder_option.h',
'include/grpcpp/ext/server_metric_recorder.h', 'include/grpcpp/ext/server_metric_recorder.h',
'include/grpcpp/generic/async_generic_service.h', 'include/grpcpp/generic/async_generic_service.h',
'include/grpcpp/generic/callback_generic_service.h',
'include/grpcpp/generic/generic_stub.h', 'include/grpcpp/generic/generic_stub.h',
'include/grpcpp/generic/generic_stub_callback.h',
'include/grpcpp/grpcpp.h', 'include/grpcpp/grpcpp.h',
'include/grpcpp/health_check_service_interface.h', 'include/grpcpp/health_check_service_interface.h',
'include/grpcpp/impl/call.h', 'include/grpcpp/impl/call.h',
@ -160,6 +162,7 @@ Pod::Spec.new do |s|
'include/grpcpp/impl/completion_queue_tag.h', 'include/grpcpp/impl/completion_queue_tag.h',
'include/grpcpp/impl/create_auth_context.h', 'include/grpcpp/impl/create_auth_context.h',
'include/grpcpp/impl/delegating_channel.h', 'include/grpcpp/impl/delegating_channel.h',
'include/grpcpp/impl/generic_stub_internal.h',
'include/grpcpp/impl/grpc_library.h', 'include/grpcpp/impl/grpc_library.h',
'include/grpcpp/impl/intercepted_channel.h', 'include/grpcpp/impl/intercepted_channel.h',
'include/grpcpp/impl/interceptor_common.h', 'include/grpcpp/impl/interceptor_common.h',

@ -20,10 +20,9 @@
#define GRPCPP_GENERIC_ASYNC_GENERIC_SERVICE_H #define GRPCPP_GENERIC_ASYNC_GENERIC_SERVICE_H
#include <grpc/support/port_platform.h> #include <grpc/support/port_platform.h>
#include <grpcpp/impl/server_callback_handlers.h> #include <grpcpp/generic/callback_generic_service.h>
#include <grpcpp/support/async_stream.h> #include <grpcpp/support/async_stream.h>
#include <grpcpp/support/byte_buffer.h> #include <grpcpp/support/byte_buffer.h>
#include <grpcpp/support/server_callback.h>
struct grpc_server; struct grpc_server;
@ -78,57 +77,6 @@ class AsyncGenericService final {
grpc::Server* server_; grpc::Server* server_;
}; };
/// \a ServerGenericBidiReactor is the reactor class for bidi streaming RPCs
/// invoked on a CallbackGenericService. It is just a ServerBidi reactor with
/// ByteBuffer arguments.
using ServerGenericBidiReactor = ServerBidiReactor<ByteBuffer, ByteBuffer>;
class GenericCallbackServerContext final : public grpc::CallbackServerContext {
public:
const std::string& method() const { return method_; }
const std::string& host() const { return host_; }
private:
friend class grpc::Server;
std::string method_;
std::string host_;
};
/// \a CallbackGenericService is the base class for generic services implemented
/// using the callback API and registered through the ServerBuilder using
/// RegisterCallbackGenericService.
class CallbackGenericService {
public:
CallbackGenericService() {}
virtual ~CallbackGenericService() {}
/// The "method handler" for the generic API. This function should be
/// overridden to provide a ServerGenericBidiReactor that implements the
/// application-level interface for this RPC. Unimplemented by default.
virtual ServerGenericBidiReactor* CreateReactor(
GenericCallbackServerContext* /*ctx*/) {
class Reactor : public ServerGenericBidiReactor {
public:
Reactor() { this->Finish(Status(StatusCode::UNIMPLEMENTED, "")); }
void OnDone() override { delete this; }
};
return new Reactor;
}
private:
friend class grpc::Server;
internal::CallbackBidiHandler<ByteBuffer, ByteBuffer>* Handler() {
return new internal::CallbackBidiHandler<ByteBuffer, ByteBuffer>(
[this](grpc::CallbackServerContext* ctx) {
return CreateReactor(static_cast<GenericCallbackServerContext*>(ctx));
});
}
grpc::Server* server_{nullptr};
};
} // namespace grpc } // namespace grpc
#endif // GRPCPP_GENERIC_ASYNC_GENERIC_SERVICE_H #endif // GRPCPP_GENERIC_ASYNC_GENERIC_SERVICE_H

@ -0,0 +1,84 @@
//
//
// Copyright 2024 gRPC authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
//
#ifndef GRPCPP_GENERIC_CALLBACK_GENERIC_SERVICE_H
#define GRPCPP_GENERIC_CALLBACK_GENERIC_SERVICE_H
#include <grpc/support/port_platform.h>
#include <grpcpp/impl/server_callback_handlers.h>
#include <grpcpp/support/byte_buffer.h>
#include <grpcpp/support/server_callback.h>
struct grpc_server;
namespace grpc {
/// \a ServerGenericBidiReactor is the reactor class for bidi streaming RPCs
/// invoked on a CallbackGenericService. It is just a ServerBidi reactor with
/// ByteBuffer arguments.
using ServerGenericBidiReactor = ServerBidiReactor<ByteBuffer, ByteBuffer>;
class GenericCallbackServerContext final : public grpc::CallbackServerContext {
public:
const std::string& method() const { return method_; }
const std::string& host() const { return host_; }
private:
friend class grpc::Server;
std::string method_;
std::string host_;
};
/// \a CallbackGenericService is the base class for generic services implemented
/// using the callback API and registered through the ServerBuilder using
/// RegisterCallbackGenericService.
class CallbackGenericService {
public:
CallbackGenericService() {}
virtual ~CallbackGenericService() {}
/// The "method handler" for the generic API. This function should be
/// overridden to provide a ServerGenericBidiReactor that implements the
/// application-level interface for this RPC. Unimplemented by default.
virtual ServerGenericBidiReactor* CreateReactor(
GenericCallbackServerContext* /*ctx*/) {
class Reactor : public ServerGenericBidiReactor {
public:
Reactor() { this->Finish(Status(StatusCode::UNIMPLEMENTED, "")); }
void OnDone() override { delete this; }
};
return new Reactor;
}
private:
friend class grpc::Server;
internal::CallbackBidiHandler<ByteBuffer, ByteBuffer>* Handler() {
return new internal::CallbackBidiHandler<ByteBuffer, ByteBuffer>(
[this](grpc::CallbackServerContext* ctx) {
return CreateReactor(static_cast<GenericCallbackServerContext*>(ctx));
});
}
grpc::Server* server_{nullptr};
};
} // namespace grpc
#endif // GRPCPP_GENERIC_CALLBACK_GENERIC_SERVICE_H

@ -19,15 +19,12 @@
#ifndef GRPCPP_GENERIC_GENERIC_STUB_H #ifndef GRPCPP_GENERIC_GENERIC_STUB_H
#define GRPCPP_GENERIC_GENERIC_STUB_H #define GRPCPP_GENERIC_GENERIC_STUB_H
#include <functional>
#include <grpcpp/client_context.h> #include <grpcpp/client_context.h>
#include <grpcpp/impl/generic_stub_internal.h>
#include <grpcpp/impl/rpc_method.h> #include <grpcpp/impl/rpc_method.h>
#include <grpcpp/support/async_stream.h> #include <grpcpp/support/async_stream.h>
#include <grpcpp/support/async_unary_call.h> #include <grpcpp/support/async_unary_call.h>
#include <grpcpp/support/byte_buffer.h> #include <grpcpp/support/byte_buffer.h>
#include <grpcpp/support/client_callback.h>
#include <grpcpp/support/status.h>
#include <grpcpp/support/stub_options.h> #include <grpcpp/support/stub_options.h>
namespace grpc { namespace grpc {
@ -42,10 +39,12 @@ typedef ClientAsyncResponseReader<ByteBuffer> GenericClientAsyncResponseReader;
/// by name. In practice, the Request and Response types should be basic /// by name. In practice, the Request and Response types should be basic
/// types like grpc::ByteBuffer or proto::MessageLite (the base protobuf). /// types like grpc::ByteBuffer or proto::MessageLite (the base protobuf).
template <class RequestType, class ResponseType> template <class RequestType, class ResponseType>
class TemplatedGenericStub final { class TemplatedGenericStub final
: public internal::TemplatedGenericStubCallbackInternal<RequestType,
ResponseType> {
public: public:
explicit TemplatedGenericStub(std::shared_ptr<grpc::ChannelInterface> channel) using internal::TemplatedGenericStubCallbackInternal<
: channel_(channel) {} RequestType, ResponseType>::TemplatedGenericStubCallbackInternal;
/// Setup a call to a named method \a method using \a context, but don't /// Setup a call to a named method \a method using \a context, but don't
/// start it. Let it be started explicitly with StartCall and a tag. /// start it. Let it be started explicitly with StartCall and a tag.
@ -74,6 +73,9 @@ class TemplatedGenericStub final {
context, request)); context, request));
} }
using internal::TemplatedGenericStubCallbackInternal<
RequestType, ResponseType>::PrepareUnaryCall;
/// DEPRECATED for multi-threaded use /// DEPRECATED for multi-threaded use
/// Begin a call to a named method \a method using \a context. /// Begin a call to a named method \a method using \a context.
/// A tag \a tag will be delivered to \a cq when the call has been started /// A tag \a tag will be delivered to \a cq when the call has been started
@ -87,72 +89,9 @@ class TemplatedGenericStub final {
true, tag); true, tag);
} }
/// Setup and start a unary call to a named method \a method using
/// \a context and specifying the \a request and \a response buffers.
void UnaryCall(ClientContext* context, const std::string& method,
StubOptions options, const RequestType* request,
ResponseType* response,
std::function<void(grpc::Status)> on_completion) {
UnaryCallInternal(context, method, options, request, response,
std::move(on_completion));
}
/// Setup a unary call to a named method \a method using
/// \a context and specifying the \a request and \a response buffers.
/// Like any other reactor-based RPC, it will not be activated until
/// StartCall is invoked on its reactor.
void PrepareUnaryCall(ClientContext* context, const std::string& method,
StubOptions options, const RequestType* request,
ResponseType* response, ClientUnaryReactor* reactor) {
PrepareUnaryCallInternal(context, method, options, request, response,
reactor);
}
/// Setup a call to a named method \a method using \a context and tied to
/// \a reactor . Like any other bidi streaming RPC, it will not be activated
/// until StartCall is invoked on its reactor.
void PrepareBidiStreamingCall(
ClientContext* context, const std::string& method, StubOptions options,
ClientBidiReactor<RequestType, ResponseType>* reactor) {
PrepareBidiStreamingCallInternal(context, method, options, reactor);
}
private: private:
std::shared_ptr<grpc::ChannelInterface> channel_; using internal::TemplatedGenericStubCallbackInternal<RequestType,
ResponseType>::channel_;
void UnaryCallInternal(ClientContext* context, const std::string& method,
StubOptions options, const RequestType* request,
ResponseType* response,
std::function<void(grpc::Status)> on_completion) {
internal::CallbackUnaryCall(
channel_.get(),
grpc::internal::RpcMethod(method.c_str(), options.suffix_for_stats(),
grpc::internal::RpcMethod::NORMAL_RPC),
context, request, response, std::move(on_completion));
}
void PrepareUnaryCallInternal(ClientContext* context,
const std::string& method, StubOptions options,
const RequestType* request,
ResponseType* response,
ClientUnaryReactor* reactor) {
internal::ClientCallbackUnaryFactory::Create<RequestType, ResponseType>(
channel_.get(),
grpc::internal::RpcMethod(method.c_str(), options.suffix_for_stats(),
grpc::internal::RpcMethod::NORMAL_RPC),
context, request, response, reactor);
}
void PrepareBidiStreamingCallInternal(
ClientContext* context, const std::string& method, StubOptions options,
ClientBidiReactor<RequestType, ResponseType>* reactor) {
internal::ClientCallbackReaderWriterFactory<RequestType, ResponseType>::
Create(channel_.get(),
grpc::internal::RpcMethod(
method.c_str(), options.suffix_for_stats(),
grpc::internal::RpcMethod::BIDI_STREAMING),
context, reactor);
}
std::unique_ptr<ClientAsyncReaderWriter<RequestType, ResponseType>> std::unique_ptr<ClientAsyncReaderWriter<RequestType, ResponseType>>
CallInternal(grpc::ChannelInterface* channel, ClientContext* context, CallInternal(grpc::ChannelInterface* channel, ClientContext* context,

@ -0,0 +1,44 @@
//
//
// Copyright 2024 gRPC authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
//
#ifndef GRPCPP_GENERIC_GENERIC_STUB_CALLBACK_H
#define GRPCPP_GENERIC_GENERIC_STUB_CALLBACK_H
#include <grpcpp/impl/generic_stub_internal.h>
#include <grpcpp/support/byte_buffer.h>
namespace grpc {
/// Generic stubs provide a type-unaware interface to call gRPC methods
/// by name. In practice, the Request and Response types should be basic
/// types like grpc::ByteBuffer or proto::MessageLite (the base protobuf).
template <class RequestType, class ResponseType>
class TemplatedGenericStubCallback final
: public internal::TemplatedGenericStubCallbackInternal<RequestType,
ResponseType> {
public:
using internal::TemplatedGenericStubCallbackInternal<
RequestType, ResponseType>::TemplatedGenericStubCallbackInternal;
};
typedef TemplatedGenericStubCallback<grpc::ByteBuffer, grpc::ByteBuffer>
GenericStubCallback;
} // namespace grpc
#endif // GRPCPP_GENERIC_GENERIC_STUB_CALLBACK_H

@ -0,0 +1,125 @@
//
//
// Copyright 2024 gRPC authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
//
#ifndef GRPCPP_IMPL_GENERIC_STUB_INTERNAL_H
#define GRPCPP_IMPL_GENERIC_STUB_INTERNAL_H
#include <functional>
#include <grpcpp/client_context.h>
#include <grpcpp/impl/rpc_method.h>
#include <grpcpp/support/byte_buffer.h>
#include <grpcpp/support/client_callback.h>
#include <grpcpp/support/status.h>
#include <grpcpp/support/stub_options.h>
namespace grpc {
template <class RequestType, class ResponseType>
class TemplatedGenericStub;
template <class RequestType, class ResponseType>
class TemplatedGenericStubCallback;
namespace internal {
/// Generic stubs provide a type-unaware interface to call gRPC methods
/// by name. In practice, the Request and Response types should be basic
/// types like grpc::ByteBuffer or proto::MessageLite (the base protobuf).
template <class RequestType, class ResponseType>
class TemplatedGenericStubCallbackInternal {
public:
explicit TemplatedGenericStubCallbackInternal(
std::shared_ptr<grpc::ChannelInterface> channel)
: channel_(channel) {}
/// Setup and start a unary call to a named method \a method using
/// \a context and specifying the \a request and \a response buffers.
void UnaryCall(ClientContext* context, const std::string& method,
StubOptions options, const RequestType* request,
ResponseType* response,
std::function<void(grpc::Status)> on_completion) {
UnaryCallInternal(context, method, options, request, response,
std::move(on_completion));
}
/// Setup a unary call to a named method \a method using
/// \a context and specifying the \a request and \a response buffers.
/// Like any other reactor-based RPC, it will not be activated until
/// StartCall is invoked on its reactor.
void PrepareUnaryCall(ClientContext* context, const std::string& method,
StubOptions options, const RequestType* request,
ResponseType* response, ClientUnaryReactor* reactor) {
PrepareUnaryCallInternal(context, method, options, request, response,
reactor);
}
/// Setup a call to a named method \a method using \a context and tied to
/// \a reactor . Like any other bidi streaming RPC, it will not be activated
/// until StartCall is invoked on its reactor.
void PrepareBidiStreamingCall(
ClientContext* context, const std::string& method, StubOptions options,
ClientBidiReactor<RequestType, ResponseType>* reactor) {
PrepareBidiStreamingCallInternal(context, method, options, reactor);
}
private:
template <class Req, class Resp>
friend class grpc::TemplatedGenericStub;
template <class Req, class Resp>
friend class grpc::TemplatedGenericStubCallback;
std::shared_ptr<grpc::ChannelInterface> channel_;
void UnaryCallInternal(ClientContext* context, const std::string& method,
StubOptions options, const RequestType* request,
ResponseType* response,
std::function<void(grpc::Status)> on_completion) {
internal::CallbackUnaryCall(
channel_.get(),
grpc::internal::RpcMethod(method.c_str(), options.suffix_for_stats(),
grpc::internal::RpcMethod::NORMAL_RPC),
context, request, response, std::move(on_completion));
}
void PrepareUnaryCallInternal(ClientContext* context,
const std::string& method, StubOptions options,
const RequestType* request,
ResponseType* response,
ClientUnaryReactor* reactor) {
internal::ClientCallbackUnaryFactory::Create<RequestType, ResponseType>(
channel_.get(),
grpc::internal::RpcMethod(method.c_str(), options.suffix_for_stats(),
grpc::internal::RpcMethod::NORMAL_RPC),
context, request, response, reactor);
}
void PrepareBidiStreamingCallInternal(
ClientContext* context, const std::string& method, StubOptions options,
ClientBidiReactor<RequestType, ResponseType>* reactor) {
internal::ClientCallbackReaderWriterFactory<RequestType, ResponseType>::
Create(channel_.get(),
grpc::internal::RpcMethod(
method.c_str(), options.suffix_for_stats(),
grpc::internal::RpcMethod::BIDI_STREAMING),
context, reactor);
}
};
} // namespace internal
} // namespace grpc
#endif // GRPCPP_IMPL_GENERIC_STUB_INTERNAL_H

@ -965,7 +965,9 @@ include/grpcpp/ext/call_metric_recorder.h \
include/grpcpp/ext/health_check_service_server_builder_option.h \ include/grpcpp/ext/health_check_service_server_builder_option.h \
include/grpcpp/ext/server_metric_recorder.h \ include/grpcpp/ext/server_metric_recorder.h \
include/grpcpp/generic/async_generic_service.h \ include/grpcpp/generic/async_generic_service.h \
include/grpcpp/generic/callback_generic_service.h \
include/grpcpp/generic/generic_stub.h \ include/grpcpp/generic/generic_stub.h \
include/grpcpp/generic/generic_stub_callback.h \
include/grpcpp/grpcpp.h \ include/grpcpp/grpcpp.h \
include/grpcpp/health_check_service_interface.h \ include/grpcpp/health_check_service_interface.h \
include/grpcpp/impl/call.h \ include/grpcpp/impl/call.h \
@ -1026,6 +1028,7 @@ include/grpcpp/impl/codegen/time.h \
include/grpcpp/impl/completion_queue_tag.h \ include/grpcpp/impl/completion_queue_tag.h \
include/grpcpp/impl/create_auth_context.h \ include/grpcpp/impl/create_auth_context.h \
include/grpcpp/impl/delegating_channel.h \ include/grpcpp/impl/delegating_channel.h \
include/grpcpp/impl/generic_stub_internal.h \
include/grpcpp/impl/grpc_library.h \ include/grpcpp/impl/grpc_library.h \
include/grpcpp/impl/intercepted_channel.h \ include/grpcpp/impl/intercepted_channel.h \
include/grpcpp/impl/interceptor_common.h \ include/grpcpp/impl/interceptor_common.h \

@ -965,7 +965,9 @@ include/grpcpp/ext/call_metric_recorder.h \
include/grpcpp/ext/health_check_service_server_builder_option.h \ include/grpcpp/ext/health_check_service_server_builder_option.h \
include/grpcpp/ext/server_metric_recorder.h \ include/grpcpp/ext/server_metric_recorder.h \
include/grpcpp/generic/async_generic_service.h \ include/grpcpp/generic/async_generic_service.h \
include/grpcpp/generic/callback_generic_service.h \
include/grpcpp/generic/generic_stub.h \ include/grpcpp/generic/generic_stub.h \
include/grpcpp/generic/generic_stub_callback.h \
include/grpcpp/grpcpp.h \ include/grpcpp/grpcpp.h \
include/grpcpp/health_check_service_interface.h \ include/grpcpp/health_check_service_interface.h \
include/grpcpp/impl/call.h \ include/grpcpp/impl/call.h \
@ -1026,6 +1028,7 @@ include/grpcpp/impl/codegen/time.h \
include/grpcpp/impl/completion_queue_tag.h \ include/grpcpp/impl/completion_queue_tag.h \
include/grpcpp/impl/create_auth_context.h \ include/grpcpp/impl/create_auth_context.h \
include/grpcpp/impl/delegating_channel.h \ include/grpcpp/impl/delegating_channel.h \
include/grpcpp/impl/generic_stub_internal.h \
include/grpcpp/impl/grpc_library.h \ include/grpcpp/impl/grpc_library.h \
include/grpcpp/impl/intercepted_channel.h \ include/grpcpp/impl/intercepted_channel.h \
include/grpcpp/impl/interceptor_common.h \ include/grpcpp/impl/interceptor_common.h \

Loading…
Cancel
Save