TYPE3
[iec.git] / src / type3_AndroidCloud / anbox-master / src / anbox / container / service.cpp
diff --git a/src/type3_AndroidCloud/anbox-master/src/anbox/container/service.cpp b/src/type3_AndroidCloud/anbox-master/src/anbox/container/service.cpp
new file mode 100644 (file)
index 0000000..71cc6e3
--- /dev/null
@@ -0,0 +1,106 @@
+/*
+ * Copyright (C) 2016 Simon Fels <morphis@gravedo.de>
+ *
+ * This program is free software: you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 3, as published
+ * by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranties of
+ * MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR
+ * PURPOSE.  See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include "anbox/container/service.h"
+#include "anbox/system_configuration.h"
+#include "anbox/container/lxc_container.h"
+#include "anbox/container/management_api_message_processor.h"
+#include "anbox/container/management_api_skeleton.h"
+#include "anbox/logger.h"
+#include "anbox/network/delegate_connection_creator.h"
+#include "anbox/network/delegate_message_processor.h"
+#include "anbox/network/local_socket_messenger.h"
+#include "anbox/qemu/null_message_processor.h"
+#include "anbox/rpc/channel.h"
+#include "anbox/rpc/pending_call_cache.h"
+
+#include <boost/filesystem.hpp>
+
+namespace fs = boost::filesystem;
+
+namespace anbox {
+namespace container {
+std::shared_ptr<Service> Service::create(const std::shared_ptr<Runtime> &rt, const Configuration &config) {
+  auto sp = std::shared_ptr<Service>(new Service(rt, config));
+
+  auto wp = std::weak_ptr<Service>(sp);
+  auto delegate_connector = std::make_shared<network::DelegateConnectionCreator<boost::asio::local::stream_protocol>>(
+      [wp](std::shared_ptr<boost::asio::local::stream_protocol::socket> const &socket) {
+        if (auto service = wp.lock())
+          service->new_client(socket);
+  });
+
+  const auto container_socket_path = SystemConfiguration::instance().container_socket_path();
+  const auto socket_parent_path = fs::path(container_socket_path).parent_path();
+  if (!fs::exists(socket_parent_path))
+    fs::create_directories(socket_parent_path);
+
+  sp->connector_ = std::make_shared<network::PublishedSocketConnector>(container_socket_path, rt, delegate_connector);
+
+  // Make sure others can connect to our socket
+  ::chmod(container_socket_path.c_str(), S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH | S_IWOTH);
+
+  DEBUG("Everything setup. Waiting for incoming connections.");
+
+  return sp;
+}
+
+Service::Service(const std::shared_ptr<Runtime> &rt, const Configuration &config)
+    : dispatcher_(anbox::common::create_dispatcher_for_runtime(rt)),
+      next_connection_id_(0),
+      connections_(std::make_shared<network::Connections<network::SocketConnection>>()),
+      config_(config) {
+}
+
+Service::~Service() {
+  connections_->clear();
+}
+
+int Service::next_id() { return next_connection_id_++; }
+
+void Service::new_client(std::shared_ptr<boost::asio::local::stream_protocol::socket> const
+        &socket) {
+  if (connections_->size() >= 1) {
+    socket->close();
+    return;
+  }
+
+  auto const messenger = std::make_shared<network::LocalSocketMessenger>(socket);
+
+  DEBUG("Got connection from pid %d", messenger->creds().pid());
+
+  auto pending_calls = std::make_shared<rpc::PendingCallCache>();
+  auto rpc_channel = std::make_shared<rpc::Channel>(pending_calls, messenger);
+  auto server = std::make_shared<container::ManagementApiSkeleton>(
+      pending_calls, std::make_shared<LxcContainer>(config_.privileged,
+                                                    config_.rootfs_overlay,
+                                                    config_.container_network_address,
+                                                    config_.container_network_gateway,
+                                                    config_.container_network_dns_servers,
+                                                    messenger->creds()));
+  auto processor = std::make_shared<container::ManagementApiMessageProcessor>(
+      messenger, pending_calls, server);
+
+  auto const &connection = std::make_shared<network::SocketConnection>(
+      messenger, messenger, next_id(), connections_, processor);
+  connection->set_name("container-service");
+
+  connections_->add(connection);
+  connection->read_next_message();
+}
+}  // namespace container
+}  // namespace anbox