2 * Copyright (C) 2016 Simon Fels <morphis@gravedo.de>
4 * This program is free software: you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License version 3, as published
6 * by the Free Software Foundation.
8 * This program is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranties of
10 * MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR
11 * PURPOSE. See the GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License along
14 * with this program. If not, see <http://www.gnu.org/licenses/>.
18 #ifndef ANBOX_BRIDGE_PLATFORM_MESSAGE_PROCESSOR_H_
19 #define ANBOX_BRIDGE_PLATFORM_MESSAGE_PROCESSOR_H_
21 #include "anbox/rpc/message_processor.h"
25 class PlatformApiSkeleton;
26 class PlatformMessageProcessor : public rpc::MessageProcessor {
28 PlatformMessageProcessor(
29 const std::shared_ptr<network::MessageSender> &sender,
30 const std::shared_ptr<PlatformApiSkeleton> &server,
31 const std::shared_ptr<rpc::PendingCallCache> &pending_calls);
32 ~PlatformMessageProcessor();
34 void dispatch(rpc::Invocation const &invocation) override;
35 void process_event_sequence(const std::string &event) override;
38 std::shared_ptr<PlatformApiSkeleton> server_;
41 } // namespace network