mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2026-04-19 10:20:22 +00:00
Consolidate the repeated socketpair + adopt + configure pattern from 4 call sites into a single Transport::create_paired() factory method. This fixes inconsistent error handling and socket configuration across call sites, and prepares for future mach port support on macOS.
73 lines
1.9 KiB
C++
73 lines
1.9 KiB
C++
/*
|
|
* Copyright (c) 2025, Tim Flynn <trflynn89@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibIPC/Transport.h>
|
|
#include <LibWebView/WebContentClient.h>
|
|
#include <LibWebView/WebUI.h>
|
|
#include <LibWebView/WebUI/ProcessesUI.h>
|
|
#include <LibWebView/WebUI/SettingsUI.h>
|
|
|
|
namespace WebView {
|
|
|
|
template<typename WebUIType>
|
|
static ErrorOr<NonnullRefPtr<WebUIType>> create_web_ui(WebContentClient& client, String host)
|
|
{
|
|
auto paired = TRY(IPC::Transport::create_paired());
|
|
auto peer_fd = TRY(paired.remote->release_underlying_transport_for_transfer());
|
|
|
|
auto web_ui = WebUIType::create(client, move(paired.local), move(host));
|
|
client.async_connect_to_web_ui(0, IPC::File::adopt_fd(peer_fd));
|
|
|
|
return web_ui;
|
|
}
|
|
|
|
ErrorOr<RefPtr<WebUI>> WebUI::create(WebContentClient& client, String host)
|
|
{
|
|
RefPtr<WebUI> web_ui;
|
|
|
|
if (host == "processes"sv)
|
|
web_ui = TRY(create_web_ui<ProcessesUI>(client, move(host)));
|
|
else if (host == "settings"sv)
|
|
web_ui = TRY(create_web_ui<SettingsUI>(client, move(host)));
|
|
|
|
if (web_ui)
|
|
web_ui->register_interfaces();
|
|
|
|
return web_ui;
|
|
}
|
|
|
|
WebUI::WebUI(WebContentClient& client, NonnullOwnPtr<IPC::Transport> transport, String host)
|
|
: IPC::ConnectionToServer<WebUIClientEndpoint, WebUIServerEndpoint>(*this, move(transport))
|
|
, m_client(client)
|
|
, m_host(move(host))
|
|
{
|
|
}
|
|
|
|
WebUI::~WebUI() = default;
|
|
|
|
void WebUI::die()
|
|
{
|
|
m_client.web_ui_disconnected({});
|
|
}
|
|
|
|
void WebUI::register_interface(StringView name, Interface interface)
|
|
{
|
|
auto result = m_interfaces.set(name, move(interface));
|
|
VERIFY(result == HashSetResult::InsertedNewEntry);
|
|
}
|
|
|
|
void WebUI::received_message(String name, JsonValue data)
|
|
{
|
|
auto interface = m_interfaces.get(name);
|
|
if (!interface.has_value()) {
|
|
warnln("Received message from WebUI for unrecognized interface: {}", name);
|
|
return;
|
|
}
|
|
|
|
interface.value()(move(data));
|
|
}
|
|
|
|
}
|