/* * Copyright (c) 2021, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #include "InspectableProcess.h" #include #include #include #include int main(int, char**) { Core::EventLoop event_loop; auto server = Core::LocalServer::construct(); if (pledge("stdio unix accept", nullptr) < 0) { perror("pledge"); return 1; } bool ok = server->take_over_from_system_server("/tmp/portal/inspector"); VERIFY(ok); server->on_ready_to_accept = [&] { auto client_socket = server->accept(); if (!client_socket) { dbgln("accept failed."); return; } static int s_next_client_id = 0; int client_id = ++s_next_client_id; IPC::new_client_connection(client_socket.release_nonnull(), client_id); }; auto inspectables_server = Core::LocalServer::construct(); if (!inspectables_server->take_over_from_system_server("/tmp/portal/inspectables")) VERIFY_NOT_REACHED(); inspectables_server->on_ready_to_accept = [&] { auto client_socket = inspectables_server->accept(); if (!client_socket) { dbgln("backdoor accept failed."); return; } auto pid = client_socket->peer_pid(); InspectorServer::g_processes.set(pid, make(pid, client_socket.release_nonnull())); }; return event_loop.exec(); }