2017-11-23 22:37:30 +08:00
|
|
|
/*
|
|
|
|
* Copyright 2017 The Cartographer 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 CARTOGRAPHER_GRPC_FRAMEWORK_RPC_HANDLER_H
|
|
|
|
#define CARTOGRAPHER_GRPC_FRAMEWORK_RPC_HANDLER_H
|
|
|
|
|
2017-11-29 21:05:31 +08:00
|
|
|
#include "cartographer_grpc/framework/execution_context.h"
|
2017-11-29 17:40:26 +08:00
|
|
|
#include "cartographer_grpc/framework/rpc.h"
|
|
|
|
#include "cartographer_grpc/framework/rpc_handler_interface.h"
|
2017-11-25 06:41:58 +08:00
|
|
|
#include "cartographer_grpc/framework/type_traits.h"
|
2017-11-29 17:40:26 +08:00
|
|
|
#include "glog/logging.h"
|
2017-11-23 22:37:30 +08:00
|
|
|
#include "google/protobuf/message.h"
|
2017-11-25 06:41:58 +08:00
|
|
|
#include "grpc++/grpc++.h"
|
2017-11-23 22:37:30 +08:00
|
|
|
|
|
|
|
namespace cartographer_grpc {
|
|
|
|
namespace framework {
|
|
|
|
|
2017-11-25 06:41:58 +08:00
|
|
|
template <typename Incoming, typename Outgoing>
|
|
|
|
class RpcHandler : public RpcHandlerInterface {
|
|
|
|
public:
|
|
|
|
using IncomingType = Incoming;
|
|
|
|
using OutgoingType = Outgoing;
|
|
|
|
using RequestType = StripStream<Incoming>;
|
|
|
|
using ResponseType = StripStream<Outgoing>;
|
2017-12-20 18:42:01 +08:00
|
|
|
|
|
|
|
class Writer {
|
|
|
|
public:
|
|
|
|
explicit Writer(std::weak_ptr<Rpc> rpc) : rpc_(std::move(rpc)) {}
|
|
|
|
bool Write(std::unique_ptr<ResponseType> message) const {
|
|
|
|
if (auto rpc = rpc_.lock()) {
|
|
|
|
rpc->Write(std::move(message));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
bool WritesDone() const {
|
|
|
|
if (auto rpc = rpc_.lock()) {
|
|
|
|
rpc->Finish(::grpc::Status::OK);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
const std::weak_ptr<Rpc> rpc_;
|
|
|
|
};
|
2017-11-28 17:50:30 +08:00
|
|
|
|
2018-01-05 17:18:08 +08:00
|
|
|
void SetExecutionContext(ExecutionContext* execution_context) override {
|
2017-11-29 21:05:31 +08:00
|
|
|
execution_context_ = execution_context;
|
|
|
|
}
|
2017-11-28 17:50:30 +08:00
|
|
|
void SetRpc(Rpc* rpc) override { rpc_ = rpc; }
|
2017-11-29 17:40:26 +08:00
|
|
|
void OnRequestInternal(const ::google::protobuf::Message* request) override {
|
|
|
|
DCHECK(dynamic_cast<const RequestType*>(request));
|
|
|
|
OnRequest(static_cast<const RequestType&>(*request));
|
|
|
|
}
|
|
|
|
virtual void OnRequest(const RequestType& request) = 0;
|
2017-12-04 22:28:19 +08:00
|
|
|
void Finish(::grpc::Status status) { rpc_->Finish(status); }
|
2017-11-29 17:40:26 +08:00
|
|
|
void Send(std::unique_ptr<ResponseType> response) {
|
|
|
|
rpc_->Write(std::move(response));
|
|
|
|
}
|
2017-11-29 21:05:31 +08:00
|
|
|
template <typename T>
|
|
|
|
ExecutionContext::Synchronized<T> GetContext() {
|
|
|
|
return {execution_context_->lock(), execution_context_};
|
|
|
|
}
|
2017-12-13 05:36:44 +08:00
|
|
|
template <typename T>
|
|
|
|
T* GetUnsynchronizedContext() {
|
|
|
|
return dynamic_cast<T*>(execution_context_);
|
|
|
|
}
|
2017-12-20 18:42:01 +08:00
|
|
|
Writer GetWriter() { return Writer(rpc_->GetWeakPtr()); }
|
2017-11-28 17:50:30 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
Rpc* rpc_;
|
2017-11-29 21:05:31 +08:00
|
|
|
ExecutionContext* execution_context_;
|
2017-11-23 22:37:30 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace framework
|
|
|
|
} // namespace cartographer_grpc
|
|
|
|
|
|
|
|
#endif // CARTOGRAPHER_GRPC_FRAMEWORK_RPC_HANDLER_H
|