Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 1 | #pragma once |
| 2 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 3 | #include "xyz/openbmc_project/Network/Client/server.hpp" |
| 4 | |
| 5 | #include <phosphor-logging/log.hpp> |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 6 | #include <sdbusplus/bus.hpp> |
| 7 | #include <sdbusplus/server/object.hpp> |
Patrick Williams | 2544b41 | 2022-10-04 08:41:06 -0500 | [diff] [blame] | 8 | |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 9 | #include <string> |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 10 | |
| 11 | namespace phosphor |
| 12 | { |
| 13 | namespace rsyslog_config |
| 14 | { |
| 15 | |
Deepak Kodihalli | 9fab279 | 2018-08-28 07:47:11 -0500 | [diff] [blame] | 16 | using namespace phosphor::logging; |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 17 | using NetworkClient = sdbusplus::xyz::openbmc_project::Network::server::Client; |
Patrick Williams | 45e8352 | 2022-07-22 19:26:52 -0500 | [diff] [blame] | 18 | using Iface = sdbusplus::server::object_t<NetworkClient>; |
Deepak Kodihalli | aabb92e | 2018-10-17 05:03:20 -0500 | [diff] [blame] | 19 | namespace sdbusRule = sdbusplus::bus::match::rules; |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 20 | |
| 21 | /** @class Server |
| 22 | * @brief Configuration for rsyslog server |
| 23 | * @details A concrete implementation of the |
| 24 | * xyz.openbmc_project.Network.Client API, in order to |
| 25 | * provide remote rsyslog server's address and port. |
| 26 | */ |
| 27 | class Server : public Iface |
| 28 | { |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 29 | public: |
| 30 | Server() = delete; |
| 31 | Server(const Server&) = delete; |
| 32 | Server& operator=(const Server&) = delete; |
| 33 | Server(Server&&) = delete; |
| 34 | Server& operator=(Server&&) = delete; |
| 35 | virtual ~Server() = default; |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 36 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 37 | /** @brief Constructor to put object onto bus at a dbus path. |
| 38 | * @param[in] bus - Bus to attach to. |
| 39 | * @param[in] path - Path to attach at. |
| 40 | * @param[in] filePath - rsyslog remote logging config file |
| 41 | */ |
Patrick Williams | 45e8352 | 2022-07-22 19:26:52 -0500 | [diff] [blame] | 42 | Server(sdbusplus::bus_t& bus, const std::string& path, |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 43 | const char* filePath) : |
Patrick Williams | 6ef6b25 | 2022-03-30 14:28:27 -0500 | [diff] [blame] | 44 | Iface(bus, path.c_str(), Iface::action::defer_emit), |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 45 | configFilePath(filePath), |
| 46 | hostnameChange( |
| 47 | bus, |
| 48 | sdbusRule::propertiesChanged("/org/freedesktop/hostname1", |
| 49 | "org.freedesktop.hostname1"), |
| 50 | std::bind(std::mem_fn(&Server::hostnameChanged), this, |
| 51 | std::placeholders::_1)) |
| 52 | { |
| 53 | try |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 54 | { |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 55 | restore(configFilePath.c_str()); |
| 56 | } |
| 57 | catch (const std::exception& e) |
| 58 | { |
| 59 | log<level::ERR>(e.what()); |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 60 | } |
| 61 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 62 | emit_object_added(); |
| 63 | } |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 64 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 65 | using NetworkClient::address; |
| 66 | using NetworkClient::port; |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 67 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 68 | /** @brief Override that updates rsyslog config file as well |
| 69 | * @param[in] value - remote server address |
| 70 | * @returns value of changed address |
| 71 | */ |
| 72 | virtual std::string address(std::string value) override; |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 73 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 74 | /** @brief Override that updates rsyslog config file as well |
| 75 | * @param[in] value - remote server port |
| 76 | * @returns value of changed port |
| 77 | */ |
| 78 | virtual uint16_t port(uint16_t value) override; |
Deepak Kodihalli | 2ce7b2c | 2018-08-31 04:22:55 -0500 | [diff] [blame] | 79 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 80 | /** @brief Restart rsyslog's systemd unit |
| 81 | */ |
| 82 | virtual void restart(); |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 83 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 84 | private: |
| 85 | /** @brief Update remote server address and port in |
| 86 | * rsyslog config file. |
| 87 | * @param[in] serverAddress - remote server address |
| 88 | * @param[in] serverPort - remote server port |
| 89 | * @param[in] filePath - rsyslog config file path |
| 90 | */ |
| 91 | void writeConfig(const std::string& serverAddress, uint16_t serverPort, |
| 92 | const char* filePath); |
Deepak Kodihalli | 4db8146 | 2018-08-27 06:01:46 -0500 | [diff] [blame] | 93 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 94 | /** @brief Checks if input IP address is valid (uses getaddrinfo) |
| 95 | * @param[in] address - server address |
| 96 | * @returns true if valid, false otherwise |
| 97 | */ |
| 98 | bool addressValid(const std::string& address); |
Deepak Kodihalli | 9fab279 | 2018-08-28 07:47:11 -0500 | [diff] [blame] | 99 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 100 | /** @brief Populate existing config into D-Bus properties |
| 101 | * @param[in] filePath - rsyslog config file path |
| 102 | */ |
| 103 | void restore(const char* filePath); |
Deepak Kodihalli | aabb92e | 2018-10-17 05:03:20 -0500 | [diff] [blame] | 104 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 105 | std::string configFilePath{}; |
Deepak Kodihalli | aabb92e | 2018-10-17 05:03:20 -0500 | [diff] [blame] | 106 | |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 107 | /** @brief React to hostname change |
| 108 | * @param[in] msg - sdbusplus message |
| 109 | */ |
Patrick Williams | 45e8352 | 2022-07-22 19:26:52 -0500 | [diff] [blame] | 110 | void hostnameChanged(sdbusplus::message_t& /*msg*/) |
Patrick Venture | f18bf83 | 2018-10-26 18:14:00 -0700 | [diff] [blame] | 111 | { |
| 112 | restart(); |
| 113 | } |
| 114 | |
| 115 | sdbusplus::bus::match_t hostnameChange; |
Deepak Kodihalli | c496619 | 2018-08-23 02:19:58 -0500 | [diff] [blame] | 116 | }; |
| 117 | |
| 118 | } // namespace rsyslog_config |
| 119 | } // namespace phosphor |