hyperledger/iroha
Iroha - A simple, decentralized ledger http://iroha.tech
mst_transport_grpc.hpp
Go to the documentation of this file.
1 
6 #ifndef IROHA_MST_TRANSPORT_GRPC_HPP
7 #define IROHA_MST_TRANSPORT_GRPC_HPP
8 
9 #include "mst.grpc.pb.h"
11 
17 #include "logger/logger_fwd.hpp"
20 
21 namespace iroha {
22 
23  namespace ametsuchi {
24  class TxPresenceCache;
25  }
26 
27  namespace network {
29  public transport::MstTransportGrpc::Service {
30  public:
31  using TransportFactoryType =
35 
38  async_call,
39  std::shared_ptr<TransportFactoryType> transaction_factory,
40  std::shared_ptr<shared_model::interface::TransactionBatchParser>
41  batch_parser,
42  std::shared_ptr<shared_model::interface::TransactionBatchFactory>
43  transaction_batch_factory,
44  std::shared_ptr<iroha::ametsuchi::TxPresenceCache> tx_presence_cache,
45  std::shared_ptr<Completer> mst_completer,
47  logger::LoggerPtr mst_state_logger,
48  logger::LoggerPtr log);
49 
57  grpc::Status SendState(
58  ::grpc::ServerContext *context,
59  const ::iroha::network::transport::MstState *request,
60  ::google::protobuf::Empty *response) override;
61 
62  void subscribe(
63  std::shared_ptr<MstTransportNotification> notification) override;
64 
65  void sendState(const shared_model::interface::Peer &to,
66  ConstRefState providing_state) override;
67 
68  private:
73  deserializeTransactions(const transport::MstState *request);
74 
75  std::weak_ptr<MstTransportNotification> subscriber_;
76  std::shared_ptr<network::AsyncGrpcClient<google::protobuf::Empty>>
77  async_call_;
78  std::shared_ptr<TransportFactoryType> transaction_factory_;
79  std::shared_ptr<shared_model::interface::TransactionBatchParser>
80  batch_parser_;
81  std::shared_ptr<shared_model::interface::TransactionBatchFactory>
82  batch_factory_;
83  std::shared_ptr<iroha::ametsuchi::TxPresenceCache> tx_presence_cache_;
85  std::shared_ptr<Completer> mst_completer_;
86  const std::string my_key_;
87 
88  logger::LoggerPtr mst_state_logger_;
89  logger::LoggerPtr log_;
91  };
92 
95  const shared_model::crypto::PublicKey &sender_key,
97 
98  } // namespace network
99 } // namespace iroha
100 
101 #endif // IROHA_MST_TRANSPORT_GRPC_HPP
Definition: peer.hpp:18
std::shared_ptr< Logger > LoggerPtr
Definition: logger_fwd.hpp:22
Definition: mst_transport_grpc.hpp:28
void sendStateAsync(const shared_model::interface::Peer &to, iroha::ConstRefState state, const shared_model::crypto::PublicKey &sender_key, AsyncGrpcClient< google::protobuf::Empty > &async_call)
Definition: mst_transport_grpc.cpp:161
Definition: block_query.hpp:16
Definition: mst_transport.hpp:37
Definition: public_key.hpp:16
Definition: async_grpc_client.hpp:25
Definition: transaction.hpp:22
std::vector< std::shared_ptr< Transaction >> SharedTxsCollectionType
Definition: transaction_sequence_common.hpp:27
ConstRefT< MstState > ConstRefState
Definition: mst_types.hpp:38