| /* |
| // Copyright (c) 2017 Intel Corporation |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| */ |
| /// \file utils.hpp |
| |
| #pragma once |
| |
| #include <boost/container/flat_map.hpp> |
| #include <nlohmann/json.hpp> |
| #include <sdbusplus/asio/connection.hpp> |
| #include <sdbusplus/exception.hpp> |
| |
| #include <filesystem> |
| |
| using DBusValueVariant = |
| std::variant<std::string, int64_t, uint64_t, double, int32_t, uint32_t, |
| int16_t, uint16_t, uint8_t, bool, std::vector<uint8_t>>; |
| using DBusInterface = boost::container::flat_map<std::string, DBusValueVariant>; |
| using DBusObject = boost::container::flat_map<std::string, DBusInterface>; |
| using MapperGetSubTreeResponse = |
| boost::container::flat_map<std::string, DBusObject>; |
| |
| bool findFiles(const std::filesystem::path& dirPath, |
| const std::string& matchString, |
| std::vector<std::filesystem::path>& foundPaths); |
| bool findFiles(const std::vector<std::filesystem::path>&& dirPaths, |
| const std::string& matchString, |
| std::vector<std::filesystem::path>& foundPaths); |
| |
| bool getI2cDevicePaths( |
| const std::filesystem::path& dirPath, |
| boost::container::flat_map<size_t, std::filesystem::path>& busPaths); |
| |
| struct DBusInternalError final : public sdbusplus::exception_t |
| { |
| const char* name() const noexcept override |
| { |
| return "org.freedesktop.DBus.Error.Failed"; |
| } |
| const char* description() const noexcept override |
| { |
| return "internal error"; |
| } |
| const char* what() const noexcept override |
| { |
| return "org.freedesktop.DBus.Error.Failed: " |
| "internal error"; |
| } |
| |
| int get_errno() const noexcept override |
| { |
| return EACCES; |
| } |
| }; |
| |
| inline bool deviceHasLogging(const nlohmann::json& json) |
| { |
| auto logging = json.find("Logging"); |
| if (logging != json.end()) |
| { |
| const auto* ptr = logging->get_ptr<const std::string*>(); |
| if (ptr != nullptr) |
| { |
| if (*ptr == "Off") |
| { |
| return false; |
| } |
| } |
| } |
| return true; |
| } |
| |
| /// \brief Match a Dbus property against a probe statement. |
| /// \param probe the probe statement to match against. |
| /// \param dbusValue the property value being matched to a probe. |
| /// \return true if the dbusValue matched the probe otherwise false. |
| bool matchProbe(const nlohmann::json& probe, const DBusValueVariant& dbusValue); |