blob: f574891289f3862f8240aefb48ec0e42c1037f81 [file] [log] [blame]
Ratan Gupta05eb1092017-04-14 16:33:53 +05301#pragma once
2
Patrick Venture189d44e2018-07-09 12:30:59 -07003#include "dhcp_configuration.hpp"
Ratan Gupta05eb1092017-04-14 16:33:53 +05304#include "ethernet_interface.hpp"
William A. Kennington IIIe0564842021-10-23 16:02:22 -07005#include "routing_table.hpp"
Ratan Guptaef85eb92017-06-15 08:57:54 +05306#include "system_configuration.hpp"
Ratan Gupta5978dd12017-07-25 13:47:13 +05307#include "vlan_interface.hpp"
Patrick Venture189d44e2018-07-09 12:30:59 -07008#include "xyz/openbmc_project/Network/VLAN/Create/server.hpp"
Ratan Gupta5978dd12017-07-25 13:47:13 +05309
Manojkiran Edaa879baa2020-06-13 14:39:08 +053010#include <filesystem>
William A. Kennington III6ff633a2021-11-09 17:09:12 -080011#include <function2/function2.hpp>
Ratan Gupta6811f822017-04-14 16:34:56 +053012#include <memory>
Patrick Venture189d44e2018-07-09 12:30:59 -070013#include <sdbusplus/bus.hpp>
Ratan Gupta05eb1092017-04-14 16:33:53 +053014#include <string>
William A. Kennington III6ff633a2021-11-09 17:09:12 -080015#include <utility>
Ratan Gupta05eb1092017-04-14 16:33:53 +053016#include <vector>
Patrick Venture189d44e2018-07-09 12:30:59 -070017#include <xyz/openbmc_project/Common/FactoryReset/server.hpp>
Ratan Gupta05eb1092017-04-14 16:33:53 +053018
19namespace phosphor
20{
21namespace network
22{
23
Ratan Gupta2b106532017-07-25 16:05:02 +053024using SystemConfPtr = std::unique_ptr<SystemConfiguration>;
25using DHCPConfPtr = std::unique_ptr<dhcp::Configuration>;
26
Manojkiran Edaa879baa2020-06-13 14:39:08 +053027namespace fs = std::filesystem;
Ratan Gupta05eb1092017-04-14 16:33:53 +053028namespace details
29{
30
Michael Tritz29f2fd62017-05-22 15:27:26 -050031template <typename T, typename U>
32using ServerObject = typename sdbusplus::server::object::object<T, U>;
Ratan Gupta05eb1092017-04-14 16:33:53 +053033
Michael Tritz29f2fd62017-05-22 15:27:26 -050034using VLANCreateIface = details::ServerObject<
35 sdbusplus::xyz::openbmc_project::Network::VLAN::server::Create,
36 sdbusplus::xyz::openbmc_project::Common::server::FactoryReset>;
Ratan Gupta05eb1092017-04-14 16:33:53 +053037
Ratan Gupta05eb1092017-04-14 16:33:53 +053038} // namespace details
39
40/** @class Manager
41 * @brief OpenBMC network manager implementation.
42 */
43class Manager : public details::VLANCreateIface
44{
Gunnar Mills57d9c502018-09-14 14:42:34 -050045 public:
46 Manager() = delete;
47 Manager(const Manager&) = delete;
48 Manager& operator=(const Manager&) = delete;
49 Manager(Manager&&) = delete;
50 Manager& operator=(Manager&&) = delete;
51 virtual ~Manager() = default;
Ratan Gupta05eb1092017-04-14 16:33:53 +053052
Gunnar Mills57d9c502018-09-14 14:42:34 -050053 /** @brief Constructor to put object onto bus at a dbus path.
54 * @param[in] bus - Bus to attach to.
55 * @param[in] objPath - Path to attach at.
56 * @param[in] dir - Network Configuration directory path.
57 */
58 Manager(sdbusplus::bus::bus& bus, const char* objPath,
59 const std::string& dir);
Ratan Gupta05eb1092017-04-14 16:33:53 +053060
Patrick Williams8173e022021-05-01 06:39:41 -050061 ObjectPath vlan(IntfName interfaceName, uint32_t id) override;
Ratan Gupta05eb1092017-04-14 16:33:53 +053062
Gunnar Mills57d9c502018-09-14 14:42:34 -050063 /** @brief write the network conf file with the in-memory objects.
64 */
65 void writeToConfigurationFile();
Ratan Gupta4f1c18b2017-05-25 12:59:35 +053066
Gunnar Mills57d9c502018-09-14 14:42:34 -050067 /** @brief Fetch the interface and the ipaddress details
68 * from the system and create the ethernet interraces
69 * dbus object.
70 */
Manojkiran Edaacd6dd52019-10-15 15:00:51 +053071 virtual void createInterfaces();
Ratan Gupta29b0e432017-05-25 12:51:40 +053072
Gunnar Mills57d9c502018-09-14 14:42:34 -050073 /** @brief create child interface object and the system conf object.
74 */
75 void createChildObjects();
Ratan Guptaef85eb92017-06-15 08:57:54 +053076
Gunnar Mills57d9c502018-09-14 14:42:34 -050077 /** @brief sets the network conf directory.
78 * @param[in] dirName - Absolute path of the directory.
79 */
80 void setConfDir(const fs::path& dir);
Ratan Guptaef85eb92017-06-15 08:57:54 +053081
Gunnar Mills57d9c502018-09-14 14:42:34 -050082 /** @brief gets the network conf directory.
83 */
84 fs::path getConfDir()
85 {
86 return confDir;
87 }
Ratan Gupta255d5142017-08-10 09:02:08 +053088
Gunnar Mills57d9c502018-09-14 14:42:34 -050089 /** @brief gets the system conf object.
90 *
91 */
92 const SystemConfPtr& getSystemConf()
93 {
94 return systemConf;
95 }
Ratan Gupta05eb1092017-04-14 16:33:53 +053096
Gunnar Mills57d9c502018-09-14 14:42:34 -050097 /** @brief gets the dhcp conf object.
98 *
99 */
100 const DHCPConfPtr& getDHCPConf()
101 {
102 return dhcpConf;
103 }
Ratan Gupta2b106532017-07-25 16:05:02 +0530104
Gunnar Mills57d9c502018-09-14 14:42:34 -0500105 /** @brief create the default network files for each interface
106 * @detail if force param is true then forcefully create the network
107 * files otherwise if network file doesn't exist then
108 * create it.
109 * @param[in] force - forcefully create the file
110 * @return true if network file created else false
111 */
112 bool createDefaultNetworkFiles(bool force);
Ratan Gupta70c7e5b2017-07-12 11:41:55 +0530113
Manojkiran Edacc099a82020-05-11 14:25:16 +0530114 /** @brief This function gets the MAC address from the VPD and
115 * sets it on the corresponding ethernet interface during first
116 * Boot, once it sets the MAC from VPD, it creates a file named
117 * firstBoot under /var/lib to make sure we dont run this function
118 * again.
119 *
120 * @param[in] ethPair - Its a pair of ethernet interface name & the
121 * corresponding MAC Address from the VPD
122 *
123 * return - NULL
124 */
125 void setFistBootMACOnInterface(
126 const std::pair<std::string, std::string>& ethPair);
127
William A. Kennington IIIc7cf25f2021-11-09 16:16:59 -0800128 /** @brief Arms a timer to tell systemd-network to reload all of the network
129 * configurations
William A. Kennington III56ecc782021-10-07 18:44:50 -0700130 */
131 virtual void reloadConfigs();
132
William A. Kennington IIIc7cf25f2021-11-09 16:16:59 -0800133 /** @brief Tell systemd-network to reload all of the network configurations
134 */
135 void doReloadConfigs();
136
Patrick Ventured94d23e2019-01-07 13:05:23 -0800137 /** @brief Returns the number of interfaces under this manager.
138 *
139 * @return the number of interfaces managed by this manager.
140 */
141 int getInterfaceCount()
142 {
143 return interfaces.size();
144 }
145
146 /** @brief Does the requested interface exist under this manager?
147 *
148 * @param[in] intf - the interface name to check.
149 * @return true if found, false otherwise.
150 */
151 bool hasInterface(const std::string& intf)
152 {
153 return (interfaces.find(intf) != interfaces.end());
154 }
155
William A. Kennington IIIe0564842021-10-23 16:02:22 -0700156 /** @brief Get the routing table owned by the manager
157 *
158 * @return Routing table reference.
159 */
160 inline const auto& getRouteTable() const
161 {
162 return routeTable;
163 }
164
William A. Kennington III6ff633a2021-11-09 17:09:12 -0800165 /** @brief Adds a hook that runs immediately prior to reloading
166 *
167 * @param[in] hook - The hook to execute before reloading
168 */
169 inline void addReloadPreHook(fu2::unique_function<void()>&& hook)
170 {
171 reloadPreHooks.push_back(std::move(hook));
172 }
173
Ratan Gupta35297172018-11-28 18:40:16 +0530174 protected:
Gunnar Mills57d9c502018-09-14 14:42:34 -0500175 /** @brief Persistent sdbusplus DBus bus connection. */
176 sdbusplus::bus::bus& bus;
Ratan Gupta29b0e432017-05-25 12:51:40 +0530177
Gunnar Mills57d9c502018-09-14 14:42:34 -0500178 /** @brief Persistent map of EthernetInterface dbus objects and their names
179 */
180 std::map<IntfName, std::shared_ptr<EthernetInterface>> interfaces;
Ratan Gupta05eb1092017-04-14 16:33:53 +0530181
Gunnar Mills57d9c502018-09-14 14:42:34 -0500182 /** @brief BMC network reset - resets network configuration for BMC. */
183 void reset() override;
Michael Tritz29f2fd62017-05-22 15:27:26 -0500184
Gunnar Mills57d9c502018-09-14 14:42:34 -0500185 /** @brief Path of Object. */
186 std::string objectPath;
Ratan Gupta29b0e432017-05-25 12:51:40 +0530187
Gunnar Mills57d9c502018-09-14 14:42:34 -0500188 /** @brief pointer to system conf object. */
189 SystemConfPtr systemConf = nullptr;
Ratan Guptaef85eb92017-06-15 08:57:54 +0530190
Gunnar Mills57d9c502018-09-14 14:42:34 -0500191 /** @brief pointer to dhcp conf object. */
192 DHCPConfPtr dhcpConf = nullptr;
Ratan Guptad16f88c2017-07-11 17:47:57 +0530193
Gunnar Mills57d9c502018-09-14 14:42:34 -0500194 /** @brief Network Configuration directory. */
195 fs::path confDir;
William A. Kennington IIIe0564842021-10-23 16:02:22 -0700196
197 /** @brief The routing table */
198 route::Table routeTable;
William A. Kennington III6ff633a2021-11-09 17:09:12 -0800199
200 /** @brief List of hooks to execute during the next reload */
201 std::vector<fu2::unique_function<void()>> reloadPreHooks;
Ratan Gupta05eb1092017-04-14 16:33:53 +0530202};
203
204} // namespace network
205} // namespace phosphor