diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 11:36:04 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 11:36:04 +0000 |
commit | 040eee1aa49b49df4698d83a05af57c220127fd1 (patch) | |
tree | f635435954e6ccde5eee9893889e24f30ca68346 /src/bin/netconf/unix_control_socket.cc | |
parent | Initial commit. (diff) | |
download | isc-kea-upstream.tar.xz isc-kea-upstream.zip |
Adding upstream version 2.2.0.upstream/2.2.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/bin/netconf/unix_control_socket.cc')
-rw-r--r-- | src/bin/netconf/unix_control_socket.cc | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/src/bin/netconf/unix_control_socket.cc b/src/bin/netconf/unix_control_socket.cc new file mode 100644 index 0000000..51ef5d1 --- /dev/null +++ b/src/bin/netconf/unix_control_socket.cc @@ -0,0 +1,97 @@ +// Copyright (C) 2018-2021 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +/// @file unix_control_socket.cc +/// Contains the UNIX socket derived class for control socket communication. + +#include <config.h> + +#include <netconf/unix_control_socket.h> +#include <asiolink/asio_wrapper.h> +#include <asiolink/io_service.h> +#include <cc/command_interpreter.h> +#include <cc/json_feed.h> +#include <config/client_connection.h> +#include <config/timeouts.h> + +using namespace std; +using namespace isc::asiolink; +using namespace isc::config; +using namespace isc::data; + +namespace isc { +namespace netconf { + +template <> ControlSocketBasePtr +createControlSocket<CfgControlSocket::Type::UNIX>(CfgControlSocketPtr ctrl_sock) { + return (UnixControlSocketPtr(new UnixControlSocket(ctrl_sock))); +} + +UnixControlSocket::UnixControlSocket(CfgControlSocketPtr ctrl_sock) + : ControlSocketBase(ctrl_sock) { +} + +ConstElementPtr +UnixControlSocket::configGet(const string& /*service*/) { + return (sendCommand(createCommand("config-get"))); +} + +ConstElementPtr +UnixControlSocket::configTest(ConstElementPtr config, + const string& /*service*/) { + return (sendCommand(createCommand("config-test", config))); +} + +ConstElementPtr +UnixControlSocket::configSet(ConstElementPtr config, + const string& /*service*/) { + return (sendCommand(createCommand("config-set", config))); +} + +ConstElementPtr +UnixControlSocket::sendCommand(ConstElementPtr command) { + // We are using our own IO service because this method is synchronous. + IOServicePtr io_service(new IOService()); + ClientConnection conn(*io_service); + boost::system::error_code received_ec; + ConstJSONFeedPtr received_feed; + + conn.start(ClientConnection::SocketPath(getName()), + ClientConnection::ControlCommand(command->toWire()), + [&io_service, &received_ec, &received_feed] + (const boost::system::error_code& ec, ConstJSONFeedPtr feed) { + // Capture error code and parsed data. + received_ec = ec; + received_feed = feed; + // Got the IO service so stop IO service. This causes to + // stop IO service when all handlers have been invoked. + io_service->stopWork(); + }, + ClientConnection::Timeout(TIMEOUT_AGENT_FORWARD_COMMAND)); + + // Perform this synchronously. + io_service->run(); + + if (received_ec) { + // Got an error. + isc_throw(ControlSocketError, "communication error: " + << received_ec.message()); + } + + if (!received_feed) { + // Failed to get the answer. + isc_throw(ControlSocketError, "empty response"); + } + + try { + return (received_feed->toElement()); + } catch (const std::exception& ex) { + isc_throw(ControlSocketError, "unparsable response: " << ex.what()); + } +} + +} // namespace netconf +} // namespace isc |