James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 1 | /* |
| 2 | // Copyright (c) 2018 Intel Corporation |
| 3 | // |
| 4 | // Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | // you may not use this file except in compliance with the License. |
| 6 | // You may obtain a copy of the License at |
| 7 | // |
| 8 | // http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | // |
| 10 | // Unless required by applicable law or agreed to in writing, software |
| 11 | // distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | // See the License for the specific language governing permissions and |
| 14 | // limitations under the License. |
| 15 | */ |
Brad Bishop | e45d8c7 | 2022-05-25 15:12:53 -0400 | [diff] [blame] | 16 | /// \file overlay.cpp |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 17 | |
Brad Bishop | e45d8c7 | 2022-05-25 15:12:53 -0400 | [diff] [blame] | 18 | #include "overlay.hpp" |
Patrick Venture | a49dc33 | 2019-10-26 08:32:02 -0700 | [diff] [blame] | 19 | |
Patrick Venture | a49dc33 | 2019-10-26 08:32:02 -0700 | [diff] [blame] | 20 | #include "devices.hpp" |
Ed Tanous | 3013fb4 | 2022-07-09 08:27:06 -0700 | [diff] [blame] | 21 | #include "utils.hpp" |
Patrick Venture | a49dc33 | 2019-10-26 08:32:02 -0700 | [diff] [blame] | 22 | |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 23 | #include <boost/algorithm/string/predicate.hpp> |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 24 | #include <boost/asio/io_context.hpp> |
| 25 | #include <boost/asio/steady_timer.hpp> |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 26 | #include <boost/container/flat_map.hpp> |
| 27 | #include <boost/container/flat_set.hpp> |
| 28 | #include <boost/process/child.hpp> |
James Feist | 8c505da | 2020-05-28 10:06:33 -0700 | [diff] [blame] | 29 | #include <nlohmann/json.hpp> |
Alexander Hansen | c3db2c3 | 2024-08-20 15:01:38 +0200 | [diff] [blame] | 30 | #include <phosphor-logging/lg2.hpp> |
James Feist | 8c505da | 2020-05-28 10:06:33 -0700 | [diff] [blame] | 31 | |
James Feist | 637b3ef | 2019-04-15 16:35:30 -0700 | [diff] [blame] | 32 | #include <filesystem> |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 33 | #include <iomanip> |
| 34 | #include <iostream> |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 35 | #include <regex> |
| 36 | #include <string> |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 37 | |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 38 | constexpr const char* outputDir = "/tmp/overlays"; |
| 39 | constexpr const char* templateChar = "$"; |
| 40 | constexpr const char* i2CDevsDir = "/sys/bus/i2c/devices"; |
| 41 | constexpr const char* muxSymlinkDir = "/dev/i2c-mux"; |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 42 | |
Ed Tanous | fc17142 | 2024-04-04 17:18:16 -0700 | [diff] [blame] | 43 | const std::regex illegalNameRegex("[^A-Za-z0-9_]"); |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 44 | |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 45 | // helper function to make json types into string |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 46 | std::string jsonToString(const nlohmann::json& in) |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 47 | { |
| 48 | if (in.type() == nlohmann::json::value_t::string) |
| 49 | { |
| 50 | return in.get<std::string>(); |
| 51 | } |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 52 | if (in.type() == nlohmann::json::value_t::array) |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 53 | { |
| 54 | // remove brackets and comma from array |
| 55 | std::string array = in.dump(); |
| 56 | array = array.substr(1, array.size() - 2); |
| 57 | boost::replace_all(array, ",", " "); |
| 58 | return array; |
| 59 | } |
| 60 | return in.dump(); |
| 61 | } |
| 62 | |
Zev Weiss | 9afef3a | 2022-07-13 16:38:23 -0700 | [diff] [blame] | 63 | static std::string deviceDirName(uint64_t bus, uint64_t address) |
| 64 | { |
| 65 | std::ostringstream name; |
Johnathan Mantey | 7b21ef2 | 2022-08-08 12:57:55 -0700 | [diff] [blame] | 66 | name << bus << "-" << std::hex << std::setw(4) << std::setfill('0') |
| 67 | << address; |
Zev Weiss | 9afef3a | 2022-07-13 16:38:23 -0700 | [diff] [blame] | 68 | return name.str(); |
| 69 | } |
| 70 | |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 71 | void linkMux(const std::string& muxName, uint64_t busIndex, uint64_t address, |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 72 | const std::vector<std::string>& channelNames) |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 73 | { |
James Feist | 286babc | 2019-02-07 16:48:28 -0800 | [diff] [blame] | 74 | std::error_code ec; |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 75 | std::filesystem::path muxSymlinkDirPath(muxSymlinkDir); |
| 76 | std::filesystem::create_directory(muxSymlinkDirPath, ec); |
Ed Tanous | ee3357a | 2019-02-26 12:44:14 -0800 | [diff] [blame] | 77 | // ignore error codes here if the directory already exists |
| 78 | ec.clear(); |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 79 | std::filesystem::path linkDir = muxSymlinkDirPath / muxName; |
Ed Tanous | ee3357a | 2019-02-26 12:44:14 -0800 | [diff] [blame] | 80 | std::filesystem::create_directory(linkDir, ec); |
| 81 | |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 82 | std::filesystem::path devDir(i2CDevsDir); |
Zev Weiss | 9afef3a | 2022-07-13 16:38:23 -0700 | [diff] [blame] | 83 | devDir /= deviceDirName(busIndex, address); |
James Feist | 286babc | 2019-02-07 16:48:28 -0800 | [diff] [blame] | 84 | |
Ed Tanous | ee3357a | 2019-02-26 12:44:14 -0800 | [diff] [blame] | 85 | for (std::size_t channelIndex = 0; channelIndex < channelNames.size(); |
| 86 | channelIndex++) |
James Feist | 286babc | 2019-02-07 16:48:28 -0800 | [diff] [blame] | 87 | { |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 88 | const std::string& channelName = channelNames[channelIndex]; |
| 89 | if (channelName.empty()) |
Ed Tanous | ee3357a | 2019-02-26 12:44:14 -0800 | [diff] [blame] | 90 | { |
| 91 | continue; |
| 92 | } |
| 93 | |
| 94 | std::filesystem::path channelPath = |
| 95 | devDir / ("channel-" + std::to_string(channelIndex)); |
| 96 | if (!is_symlink(channelPath)) |
| 97 | { |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 98 | std::cerr << channelPath << " for mux channel " << channelName |
Ed Tanous | ee3357a | 2019-02-26 12:44:14 -0800 | [diff] [blame] | 99 | << " doesn't exist!\n"; |
| 100 | continue; |
| 101 | } |
| 102 | std::filesystem::path bus = std::filesystem::read_symlink(channelPath); |
| 103 | |
| 104 | std::filesystem::path fp("/dev" / bus.filename()); |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 105 | std::filesystem::path link(linkDir / channelName); |
Ed Tanous | ee3357a | 2019-02-26 12:44:14 -0800 | [diff] [blame] | 106 | |
| 107 | std::filesystem::create_symlink(fp, link, ec); |
| 108 | if (ec) |
| 109 | { |
| 110 | std::cerr << "Failure creating symlink for " << fp << " to " << link |
| 111 | << "\n"; |
| 112 | } |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 113 | } |
| 114 | } |
| 115 | |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 116 | static int deleteDevice(const std::string& busPath, uint64_t address, |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 117 | const std::string& destructor) |
| 118 | { |
Zev Weiss | c11b5da | 2022-07-12 16:31:37 -0700 | [diff] [blame] | 119 | std::filesystem::path deviceDestructor(busPath); |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 120 | deviceDestructor /= destructor; |
| 121 | std::ofstream deviceFile(deviceDestructor); |
| 122 | if (!deviceFile.good()) |
| 123 | { |
| 124 | std::cerr << "Error writing " << deviceDestructor << "\n"; |
| 125 | return -1; |
| 126 | } |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 127 | deviceFile << std::to_string(address); |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 128 | deviceFile.close(); |
| 129 | return 0; |
| 130 | } |
| 131 | |
Zev Weiss | c11b5da | 2022-07-12 16:31:37 -0700 | [diff] [blame] | 132 | static int createDevice(const std::string& busPath, |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 133 | const std::string& parameters, |
| 134 | const std::string& constructor) |
| 135 | { |
Zev Weiss | c11b5da | 2022-07-12 16:31:37 -0700 | [diff] [blame] | 136 | std::filesystem::path deviceConstructor(busPath); |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 137 | deviceConstructor /= constructor; |
| 138 | std::ofstream deviceFile(deviceConstructor); |
| 139 | if (!deviceFile.good()) |
| 140 | { |
| 141 | std::cerr << "Error writing " << deviceConstructor << "\n"; |
| 142 | return -1; |
| 143 | } |
| 144 | deviceFile << parameters; |
| 145 | deviceFile.close(); |
| 146 | |
| 147 | return 0; |
| 148 | } |
| 149 | |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 150 | static bool deviceIsCreated(const std::string& busPath, uint64_t bus, |
| 151 | uint64_t address, |
Johnathan Mantey | 7b21ef2 | 2022-08-08 12:57:55 -0700 | [diff] [blame] | 152 | const devices::createsHWMon hasHWMonDir) |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 153 | { |
Zev Weiss | 67003d6 | 2022-07-15 16:38:19 -0700 | [diff] [blame] | 154 | std::filesystem::path dirPath = busPath; |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 155 | dirPath /= deviceDirName(bus, address); |
Johnathan Mantey | 7b21ef2 | 2022-08-08 12:57:55 -0700 | [diff] [blame] | 156 | if (hasHWMonDir == devices::createsHWMon::hasHWMonDir) |
Zev Weiss | 67003d6 | 2022-07-15 16:38:19 -0700 | [diff] [blame] | 157 | { |
| 158 | dirPath /= "hwmon"; |
| 159 | } |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 160 | |
Ed Tanous | 37e142b | 2021-04-30 12:19:26 -0700 | [diff] [blame] | 161 | std::error_code ec; |
Zev Weiss | 67003d6 | 2022-07-15 16:38:19 -0700 | [diff] [blame] | 162 | // Ignore errors; anything but a clean 'true' is just fine as 'false' |
| 163 | return std::filesystem::exists(dirPath, ec); |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 164 | } |
| 165 | |
Patrick Williams | b707743 | 2024-08-16 15:22:21 -0400 | [diff] [blame] | 166 | static int |
| 167 | buildDevice(const std::string& name, const std::string& busPath, |
| 168 | const std::string& parameters, uint64_t bus, uint64_t address, |
| 169 | const std::string& constructor, const std::string& destructor, |
| 170 | const devices::createsHWMon hasHWMonDir, |
| 171 | std::vector<std::string> channelNames, const size_t retries = 5) |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 172 | { |
Ed Tanous | 3013fb4 | 2022-07-09 08:27:06 -0700 | [diff] [blame] | 173 | if (retries == 0U) |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 174 | { |
| 175 | return -1; |
| 176 | } |
| 177 | |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 178 | // If it's already instantiated, we don't need to create it again. |
Johnathan Mantey | 7b21ef2 | 2022-08-08 12:57:55 -0700 | [diff] [blame] | 179 | if (!deviceIsCreated(busPath, bus, address, hasHWMonDir)) |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 180 | { |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 181 | // Try to create the device |
| 182 | createDevice(busPath, parameters, constructor); |
Zev Weiss | cbcd17f | 2022-07-15 15:39:21 -0700 | [diff] [blame] | 183 | |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 184 | // If it didn't work, delete it and try again in 500ms |
| 185 | if (!deviceIsCreated(busPath, bus, address, hasHWMonDir)) |
| 186 | { |
| 187 | deleteDevice(busPath, address, destructor); |
| 188 | |
| 189 | std::shared_ptr<boost::asio::steady_timer> createTimer = |
| 190 | std::make_shared<boost::asio::steady_timer>(io); |
| 191 | createTimer->expires_after(std::chrono::milliseconds(500)); |
| 192 | createTimer->async_wait( |
| 193 | [createTimer, name, busPath, parameters, bus, address, |
| 194 | constructor, destructor, hasHWMonDir, |
| 195 | channelNames(std::move(channelNames)), |
| 196 | retries](const boost::system::error_code& ec) mutable { |
Patrick Williams | b707743 | 2024-08-16 15:22:21 -0400 | [diff] [blame] | 197 | if (ec) |
| 198 | { |
| 199 | std::cerr << "Timer error: " << ec << "\n"; |
| 200 | return -2; |
| 201 | } |
| 202 | return buildDevice(name, busPath, parameters, bus, address, |
| 203 | constructor, destructor, hasHWMonDir, |
| 204 | std::move(channelNames), retries - 1); |
| 205 | }); |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 206 | return -1; |
| 207 | } |
| 208 | } |
| 209 | |
| 210 | // Link the mux channels if needed once the device is created. |
| 211 | if (!channelNames.empty()) |
| 212 | { |
| 213 | linkMux(name, bus, address, channelNames); |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 214 | } |
Zev Weiss | cbcd17f | 2022-07-15 15:39:21 -0700 | [diff] [blame] | 215 | |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 216 | return 0; |
| 217 | } |
| 218 | |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 219 | void exportDevice(const std::string& type, |
| 220 | const devices::ExportTemplate& exportTemplate, |
| 221 | const nlohmann::json& configuration) |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 222 | { |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 223 | std::string parameters = exportTemplate.parameters; |
Zev Weiss | c11b5da | 2022-07-12 16:31:37 -0700 | [diff] [blame] | 224 | std::string busPath = exportTemplate.busPath; |
Johnathan Mantey | 9b86787 | 2020-10-13 15:00:51 -0700 | [diff] [blame] | 225 | std::string constructor = exportTemplate.add; |
| 226 | std::string destructor = exportTemplate.remove; |
Johnathan Mantey | 7b21ef2 | 2022-08-08 12:57:55 -0700 | [diff] [blame] | 227 | devices::createsHWMon hasHWMonDir = exportTemplate.hasHWMonDir; |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 228 | std::string name = "unknown"; |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 229 | std::optional<uint64_t> bus; |
| 230 | std::optional<uint64_t> address; |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 231 | std::vector<std::string> channels; |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 232 | |
| 233 | for (auto keyPair = configuration.begin(); keyPair != configuration.end(); |
| 234 | keyPair++) |
| 235 | { |
| 236 | std::string subsituteString; |
| 237 | |
| 238 | if (keyPair.key() == "Name" && |
| 239 | keyPair.value().type() == nlohmann::json::value_t::string) |
| 240 | { |
| 241 | subsituteString = std::regex_replace( |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 242 | keyPair.value().get<std::string>(), illegalNameRegex, "_"); |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 243 | name = subsituteString; |
| 244 | } |
| 245 | else |
| 246 | { |
| 247 | subsituteString = jsonToString(keyPair.value()); |
| 248 | } |
| 249 | |
| 250 | if (keyPair.key() == "Bus") |
| 251 | { |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 252 | bus = keyPair.value().get<uint64_t>(); |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 253 | } |
| 254 | else if (keyPair.key() == "Address") |
| 255 | { |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 256 | address = keyPair.value().get<uint64_t>(); |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 257 | } |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 258 | else if (keyPair.key() == "ChannelNames" && type.ends_with("Mux")) |
James Feist | 286babc | 2019-02-07 16:48:28 -0800 | [diff] [blame] | 259 | { |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 260 | channels = keyPair.value().get<std::vector<std::string>>(); |
James Feist | 286babc | 2019-02-07 16:48:28 -0800 | [diff] [blame] | 261 | } |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 262 | boost::replace_all(parameters, templateChar + keyPair.key(), |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 263 | subsituteString); |
Zev Weiss | c11b5da | 2022-07-12 16:31:37 -0700 | [diff] [blame] | 264 | boost::replace_all(busPath, templateChar + keyPair.key(), |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 265 | subsituteString); |
| 266 | } |
| 267 | |
Jonathan Doman | d0eb129 | 2023-04-19 11:21:56 -0700 | [diff] [blame] | 268 | if (!bus || !address) |
| 269 | { |
| 270 | createDevice(busPath, parameters, constructor); |
| 271 | return; |
| 272 | } |
| 273 | |
Jonathan Doman | 6af72c9 | 2023-04-19 11:55:39 -0700 | [diff] [blame] | 274 | buildDevice(name, busPath, parameters, *bus, *address, constructor, |
| 275 | destructor, hasHWMonDir, std::move(channels)); |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 276 | } |
| 277 | |
James Feist | a465ccc | 2019-02-08 12:51:01 -0800 | [diff] [blame] | 278 | bool loadOverlays(const nlohmann::json& systemConfiguration) |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 279 | { |
Ed Tanous | 07d467b | 2021-02-23 14:48:37 -0800 | [diff] [blame] | 280 | std::filesystem::create_directory(outputDir); |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 281 | for (auto entity = systemConfiguration.begin(); |
| 282 | entity != systemConfiguration.end(); entity++) |
| 283 | { |
James Feist | 1e3e698 | 2018-08-03 16:09:28 -0700 | [diff] [blame] | 284 | auto findExposes = entity.value().find("Exposes"); |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 285 | if (findExposes == entity.value().end() || |
| 286 | findExposes->type() != nlohmann::json::value_t::array) |
| 287 | { |
| 288 | continue; |
| 289 | } |
| 290 | |
Ed Tanous | 3013fb4 | 2022-07-09 08:27:06 -0700 | [diff] [blame] | 291 | for (const auto& configuration : *findExposes) |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 292 | { |
James Feist | 1e3e698 | 2018-08-03 16:09:28 -0700 | [diff] [blame] | 293 | auto findStatus = configuration.find("Status"); |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 294 | // status missing is assumed to be 'okay' |
| 295 | if (findStatus != configuration.end() && *findStatus == "disabled") |
| 296 | { |
| 297 | continue; |
| 298 | } |
James Feist | d63d18a | 2018-07-19 15:23:45 -0700 | [diff] [blame] | 299 | auto findType = configuration.find("Type"); |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 300 | if (findType == configuration.end() || |
| 301 | findType->type() != nlohmann::json::value_t::string) |
| 302 | { |
| 303 | continue; |
| 304 | } |
| 305 | std::string type = findType.value().get<std::string>(); |
James Feist | 053a664 | 2018-10-15 13:17:09 -0700 | [diff] [blame] | 306 | auto device = devices::exportTemplates.find(type.c_str()); |
| 307 | if (device != devices::exportTemplates.end()) |
| 308 | { |
James Feist | 286babc | 2019-02-07 16:48:28 -0800 | [diff] [blame] | 309 | exportDevice(type, device->second, configuration); |
Josh Lehan | 96b8a6e | 2019-10-09 14:39:49 -0700 | [diff] [blame] | 310 | continue; |
| 311 | } |
| 312 | |
| 313 | // Because many devices are intentionally not exportable, |
| 314 | // this error message is not printed in all situations. |
| 315 | // If wondering why your device not appearing, add your type to |
| 316 | // the exportTemplates array in the devices.hpp file. |
Alexander Hansen | c3db2c3 | 2024-08-20 15:01:38 +0200 | [diff] [blame] | 317 | lg2::debug("Device type {TYPE} not found in export map allowlist", |
| 318 | "TYPE", type); |
James Feist | c95cb14 | 2018-02-26 10:41:42 -0800 | [diff] [blame] | 319 | } |
| 320 | } |
| 321 | |
| 322 | return true; |
Jae Hyun Yoo | 6d1d014 | 2018-07-25 10:07:43 -0700 | [diff] [blame] | 323 | } |