2019-05-20 06:21:02 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2019- Equinor ASA
|
|
|
|
//
|
|
|
|
// ResInsight is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
//
|
|
|
|
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <QString>
|
|
|
|
#include <grpc/support/log.h>
|
|
|
|
#include <grpcpp/grpcpp.h>
|
2019-11-26 02:29:38 -06:00
|
|
|
#include <grpcpp/server_context.h>
|
|
|
|
#include <grpcpp/support/async_stream.h>
|
|
|
|
#include <grpcpp/support/async_unary_call.h>
|
|
|
|
#include <grpcpp/support/sync_stream.h>
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
using grpc::CompletionQueue;
|
2019-05-22 08:30:09 -05:00
|
|
|
using grpc::ServerAsyncReader;
|
2019-09-06 03:40:57 -05:00
|
|
|
using grpc::ServerAsyncResponseWriter;
|
2019-05-20 06:21:02 -05:00
|
|
|
using grpc::ServerAsyncWriter;
|
|
|
|
using grpc::ServerCompletionQueue;
|
|
|
|
using grpc::ServerContext;
|
|
|
|
using grpc::Status;
|
|
|
|
|
|
|
|
class RiaGrpcServiceInterface;
|
|
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
//
|
|
|
|
// Base class for all gRPC-callbacks
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
2019-05-27 00:29:20 -05:00
|
|
|
class RiaGrpcCallbackInterface
|
2019-05-20 06:21:02 -05:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum CallState
|
|
|
|
{
|
|
|
|
CREATE_HANDLER,
|
2019-05-22 08:30:09 -05:00
|
|
|
INIT_REQUEST_STARTED,
|
|
|
|
INIT_REQUEST_COMPLETED,
|
2019-05-20 06:21:02 -05:00
|
|
|
PROCESS_REQUEST,
|
|
|
|
FINISH_REQUEST
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
2019-05-27 00:29:20 -05:00
|
|
|
inline RiaGrpcCallbackInterface();
|
2019-05-20 06:21:02 -05:00
|
|
|
|
2019-05-27 00:29:20 -05:00
|
|
|
virtual ~RiaGrpcCallbackInterface() {}
|
2019-09-06 03:40:57 -05:00
|
|
|
virtual QString name() const = 0;
|
|
|
|
virtual RiaGrpcCallbackInterface* createNewFromThis() const = 0;
|
|
|
|
virtual void createRequestHandler( ServerCompletionQueue* completionQueue ) = 0;
|
2019-05-27 00:29:20 -05:00
|
|
|
virtual void onInitRequestStarted() {}
|
|
|
|
virtual void onInitRequestCompleted() {}
|
2019-09-06 03:40:57 -05:00
|
|
|
virtual void onProcessRequest() = 0;
|
2019-05-27 00:29:20 -05:00
|
|
|
virtual void onFinishRequest() {}
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
inline CallState callState() const;
|
|
|
|
inline const Status& status() const;
|
2019-09-06 03:40:57 -05:00
|
|
|
inline void setNextCallState( CallState state );
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
protected:
|
|
|
|
CallState m_state;
|
|
|
|
Status m_status;
|
|
|
|
};
|
|
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
//
|
|
|
|
// Templated gRPC-callback base class
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
2019-09-06 03:40:57 -05:00
|
|
|
template <typename ServiceT, typename RequestT, typename ReplyT>
|
2019-05-27 00:29:20 -05:00
|
|
|
class RiaGrpcServiceCallback : public RiaGrpcCallbackInterface
|
2019-05-20 06:21:02 -05:00
|
|
|
{
|
|
|
|
public:
|
2019-09-06 03:40:57 -05:00
|
|
|
RiaGrpcServiceCallback( ServiceT* service );
|
2022-03-03 03:15:32 -06:00
|
|
|
~RiaGrpcServiceCallback();
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
QString name() const override;
|
|
|
|
const RequestT& request() const;
|
|
|
|
ReplyT& reply();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual QString methodType() const = 0;
|
|
|
|
|
|
|
|
protected:
|
2019-09-06 03:40:57 -05:00
|
|
|
ServiceT* m_service;
|
|
|
|
RequestT m_request;
|
|
|
|
ReplyT m_reply;
|
2019-05-20 06:21:02 -05:00
|
|
|
};
|
|
|
|
|
2022-03-03 03:15:32 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
template <typename ServiceT, typename RequestT, typename ReplyT>
|
|
|
|
RiaGrpcServiceCallback<ServiceT, RequestT, ReplyT>::~RiaGrpcServiceCallback()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2019-05-20 06:21:02 -05:00
|
|
|
//==================================================================================================
|
|
|
|
//
|
|
|
|
// Templated gRPC-callback for non-streaming services
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
2019-09-06 03:40:57 -05:00
|
|
|
template <typename ServiceT, typename RequestT, typename ReplyT>
|
2019-05-27 00:29:20 -05:00
|
|
|
class RiaGrpcUnaryCallback : public RiaGrpcServiceCallback<ServiceT, RequestT, ReplyT>
|
2019-05-20 06:21:02 -05:00
|
|
|
{
|
|
|
|
public:
|
2019-11-07 04:42:47 -06:00
|
|
|
using ResponseWriterT = ServerAsyncResponseWriter<ReplyT>;
|
|
|
|
using MethodImplT = std::function<Status( ServiceT&, ServerContext*, const RequestT*, ReplyT* )>;
|
|
|
|
using MethodRequestT = std::function<
|
|
|
|
void( ServiceT&, ServerContext*, RequestT*, ResponseWriterT*, CompletionQueue*, ServerCompletionQueue*, void* )>;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
RiaGrpcUnaryCallback( ServiceT* service, MethodImplT methodImpl, MethodRequestT methodRequest );
|
2019-05-20 06:21:02 -05:00
|
|
|
|
2019-05-27 00:29:20 -05:00
|
|
|
RiaGrpcCallbackInterface* createNewFromThis() const override;
|
2019-09-06 03:40:57 -05:00
|
|
|
void createRequestHandler( ServerCompletionQueue* completionQueue ) override;
|
|
|
|
void onProcessRequest() override;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
protected:
|
2020-09-14 14:47:48 -05:00
|
|
|
virtual QString methodType() const override;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
private:
|
|
|
|
ServerContext m_context;
|
|
|
|
ResponseWriterT m_responder;
|
|
|
|
MethodImplT m_methodImpl;
|
|
|
|
MethodRequestT m_methodRequest;
|
|
|
|
};
|
|
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
//
|
2019-05-23 02:58:04 -05:00
|
|
|
// Templated server->client *streaming* gRPC-callback calling service implementation callbacks
|
2019-05-20 06:21:02 -05:00
|
|
|
//
|
|
|
|
// The streaming callback needs a state handler for setting up and maintaining order.
|
|
|
|
//
|
2019-05-23 02:58:04 -05:00
|
|
|
// A fully functional state handler for server->client streaming needs to implement the following methods:
|
2019-05-20 06:21:02 -05:00
|
|
|
// 1. Default Constructor
|
|
|
|
// 2. grpc::Status init(const grpc::Message* request)
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
2019-09-06 03:40:57 -05:00
|
|
|
template <typename ServiceT, typename RequestT, typename ReplyT, typename StateHandlerT>
|
2019-08-13 01:23:03 -05:00
|
|
|
class RiaGrpcServerToClientStreamCallback : public RiaGrpcServiceCallback<ServiceT, RequestT, ReplyT>
|
2019-05-20 06:21:02 -05:00
|
|
|
{
|
|
|
|
public:
|
2019-11-07 04:42:47 -06:00
|
|
|
using ResponseWriterT = ServerAsyncWriter<ReplyT>;
|
|
|
|
using MethodImplT = std::function<Status( ServiceT&, ServerContext*, const RequestT*, ReplyT*, StateHandlerT* )>;
|
|
|
|
using MethodRequestT = std::function<
|
|
|
|
void( ServiceT&, ServerContext*, RequestT*, ResponseWriterT*, CompletionQueue*, ServerCompletionQueue*, void* )>;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
RiaGrpcServerToClientStreamCallback( ServiceT* service,
|
|
|
|
MethodImplT methodImpl,
|
|
|
|
MethodRequestT methodRequest,
|
|
|
|
StateHandlerT* stateHandler );
|
2019-05-20 06:21:02 -05:00
|
|
|
|
2019-05-27 00:29:20 -05:00
|
|
|
RiaGrpcCallbackInterface* createNewFromThis() const override;
|
2019-09-06 03:40:57 -05:00
|
|
|
void createRequestHandler( ServerCompletionQueue* completionQueue ) override;
|
|
|
|
void onInitRequestCompleted() override;
|
|
|
|
void onProcessRequest() override;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
protected:
|
2020-09-14 14:47:48 -05:00
|
|
|
virtual QString methodType() const override;
|
2019-05-20 06:21:02 -05:00
|
|
|
|
|
|
|
private:
|
2019-09-06 03:40:57 -05:00
|
|
|
ServerContext m_context;
|
|
|
|
ResponseWriterT m_responder;
|
|
|
|
MethodImplT m_methodImpl;
|
|
|
|
MethodRequestT m_methodRequest;
|
2019-05-20 06:21:02 -05:00
|
|
|
std::unique_ptr<StateHandlerT> m_stateHandler;
|
|
|
|
};
|
|
|
|
|
2019-05-22 08:30:09 -05:00
|
|
|
//==================================================================================================
|
|
|
|
//
|
2019-05-23 02:58:04 -05:00
|
|
|
// Templated client->server *streaming* gRPC-callback calling service implementation callbacks
|
2019-05-22 08:30:09 -05:00
|
|
|
//
|
|
|
|
// The streaming callback needs a state handler for setting up and maintaining order.
|
|
|
|
//
|
2019-05-23 02:58:04 -05:00
|
|
|
// A fully functional state handler for client->server streaming needs to implement the following methods:
|
2019-05-22 08:30:09 -05:00
|
|
|
// 1. Default Constructor
|
|
|
|
// 2. grpc::Status init(const grpc::Message* request)
|
|
|
|
// 3. void finish() any updates required after completion
|
|
|
|
//
|
|
|
|
//==================================================================================================
|
2019-09-06 03:40:57 -05:00
|
|
|
template <typename ServiceT, typename RequestT, typename ReplyT, typename StateHandlerT>
|
2019-08-13 01:23:03 -05:00
|
|
|
class RiaGrpcClientToServerStreamCallback : public RiaGrpcServiceCallback<ServiceT, RequestT, ReplyT>
|
2019-05-22 08:30:09 -05:00
|
|
|
{
|
|
|
|
public:
|
2019-11-07 04:42:47 -06:00
|
|
|
using RequestReaderT = ServerAsyncReader<ReplyT, RequestT>;
|
|
|
|
using MethodImplT = std::function<Status( ServiceT&, ServerContext*, const RequestT*, ReplyT*, StateHandlerT* )>;
|
|
|
|
using MethodRequestT =
|
|
|
|
std::function<void( ServiceT&, ServerContext*, RequestReaderT*, CompletionQueue*, ServerCompletionQueue*, void* )>;
|
2019-05-22 08:30:09 -05:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
RiaGrpcClientToServerStreamCallback( ServiceT* service,
|
|
|
|
MethodImplT methodImpl,
|
|
|
|
MethodRequestT methodRequest,
|
|
|
|
StateHandlerT* stateHandler );
|
2019-05-22 08:30:09 -05:00
|
|
|
|
2019-05-27 00:29:20 -05:00
|
|
|
RiaGrpcCallbackInterface* createNewFromThis() const override;
|
2019-09-06 03:40:57 -05:00
|
|
|
void createRequestHandler( ServerCompletionQueue* completionQueue ) override;
|
|
|
|
void onInitRequestStarted() override;
|
|
|
|
void onInitRequestCompleted() override;
|
|
|
|
void onProcessRequest() override;
|
|
|
|
void onFinishRequest() override;
|
2019-05-22 08:30:09 -05:00
|
|
|
|
|
|
|
protected:
|
2020-09-14 14:47:48 -05:00
|
|
|
virtual QString methodType() const override;
|
2019-05-22 08:30:09 -05:00
|
|
|
|
|
|
|
private:
|
2019-09-06 03:40:57 -05:00
|
|
|
ServerContext m_context;
|
|
|
|
RequestReaderT m_reader;
|
|
|
|
MethodImplT m_methodImpl;
|
|
|
|
MethodRequestT m_methodRequest;
|
2019-05-22 08:30:09 -05:00
|
|
|
std::unique_ptr<StateHandlerT> m_stateHandler;
|
|
|
|
};
|
|
|
|
|
2019-05-20 06:21:02 -05:00
|
|
|
#include "RiaGrpcCallbacks.inl"
|