blob: d480c430efcf5d404586506392f34629bdc9a590 [file] [log] [blame]
Saqib Khan167601b2017-06-18 23:33:46 -05001#include "version.hpp"
Gunnar Millsf6ed5892018-09-07 17:08:02 -05002
Leonel Gonzalez9c8adfa2017-07-12 11:08:40 -05003#include "item_updater.hpp"
Gunnar Millsf6ed5892018-09-07 17:08:02 -05004#include "xyz/openbmc_project/Common/error.hpp"
5
Adriana Kobylak5e0b2372021-12-08 21:59:30 +00006#include <openssl/evp.h>
Saqib Khan167601b2017-06-18 23:33:46 -05007
Gunnar Millsf6ed5892018-09-07 17:08:02 -05008#include <phosphor-logging/elog-errors.hpp>
9#include <phosphor-logging/log.hpp>
Brad Bishop8facccf2020-11-04 09:44:58 -050010
11#include <fstream>
12#include <iostream>
Gunnar Millsf6ed5892018-09-07 17:08:02 -050013#include <sstream>
14#include <stdexcept>
15#include <string>
16
Saqib Khan167601b2017-06-18 23:33:46 -050017namespace openpower
18{
19namespace software
20{
21namespace updater
22{
23
24using namespace sdbusplus::xyz::openbmc_project::Common::Error;
25using namespace phosphor::logging;
Gunnar Millsa93a07b2017-09-21 15:40:09 -050026using Argument = xyz::openbmc_project::Common::InvalidArgument;
Saqib Khan167601b2017-06-18 23:33:46 -050027
Adriana Kobylak5e0b2372021-12-08 21:59:30 +000028using EVP_MD_CTX_Ptr =
29 std::unique_ptr<EVP_MD_CTX, decltype(&::EVP_MD_CTX_free)>;
30
Saqib Khan167601b2017-06-18 23:33:46 -050031std::string Version::getId(const std::string& version)
32{
Saqib Khan167601b2017-06-18 23:33:46 -050033
34 if (version.empty())
35 {
36 log<level::ERR>("Error version is empty");
Lei YU91add6d2019-03-01 14:23:40 +080037 return {};
Saqib Khan167601b2017-06-18 23:33:46 -050038 }
39
Adriana Kobylak5e0b2372021-12-08 21:59:30 +000040 std::array<unsigned char, EVP_MAX_MD_SIZE> digest{};
41 EVP_MD_CTX_Ptr ctx(EVP_MD_CTX_new(), &::EVP_MD_CTX_free);
Saqib Khan2308b8b2017-09-19 15:33:06 -050042
Adriana Kobylak5e0b2372021-12-08 21:59:30 +000043 EVP_DigestInit(ctx.get(), EVP_sha512());
44 EVP_DigestUpdate(ctx.get(), version.c_str(), strlen(version.c_str()));
45 EVP_DigestFinal(ctx.get(), digest.data(), nullptr);
46
47 // We are only using the first 8 characters.
48 char mdString[9];
49 snprintf(mdString, sizeof(mdString), "%02x%02x%02x%02x",
50 (unsigned int)digest[0], (unsigned int)digest[1],
51 (unsigned int)digest[2], (unsigned int)digest[3]);
52
53 return mdString;
Saqib Khan167601b2017-06-18 23:33:46 -050054}
55
Adriana Kobylak70dcb632018-02-27 15:46:52 -060056std::map<std::string, std::string>
57 Version::getValue(const std::string& filePath,
58 std::map<std::string, std::string> keys)
Saqib Khan167601b2017-06-18 23:33:46 -050059{
Saqib Khan167601b2017-06-18 23:33:46 -050060 if (filePath.empty())
61 {
62 log<level::ERR>("Error filePath is empty");
Gunnar Millsa93a07b2017-09-21 15:40:09 -050063 elog<InvalidArgument>(Argument::ARGUMENT_NAME("FilePath"),
64 Argument::ARGUMENT_VALUE(filePath.c_str()));
Saqib Khan167601b2017-06-18 23:33:46 -050065 }
66
67 std::ifstream efile;
68 std::string line;
Adriana Kobylak70dcb632018-02-27 15:46:52 -060069 efile.exceptions(std::ifstream::failbit | std::ifstream::badbit |
Gunnar Millsa93a07b2017-09-21 15:40:09 -050070 std::ifstream::eofbit);
Saqib Khan167601b2017-06-18 23:33:46 -050071
72 try
73 {
74 efile.open(filePath);
75 while (getline(efile, line))
76 {
Adriana Kobylak70dcb632018-02-27 15:46:52 -060077 for (auto& key : keys)
Saqib Khan167601b2017-06-18 23:33:46 -050078 {
79 auto value = key.first + "=";
80 auto keySize = value.length();
81 if (line.compare(0, keySize, value) == 0)
82 {
83 key.second = line.substr(keySize);
84 break;
85 }
86 }
87 }
88 efile.close();
89 }
90 catch (const std::exception& e)
91 {
Saqib Khane53222d2017-08-19 16:57:24 -050092 if (!efile.eof())
93 {
94 log<level::ERR>("Error in reading file");
95 }
96 efile.close();
Saqib Khan167601b2017-06-18 23:33:46 -050097 }
98
99 return keys;
100}
101
Lei YUdec8cf92019-02-21 17:47:05 +0800102std::pair<std::string, std::string>
103 Version::getVersions(const std::string& versionPart)
104{
105 // versionPart contains strings like below:
106 // open-power-romulus-v2.2-rc1-48-g268344f-dirty
107 // buildroot-2018.11.1-7-g5d7cc8c
108 // skiboot-v6.2
109 std::istringstream iss(versionPart);
110 std::string line;
111 std::string version;
112 std::stringstream ss;
113 std::string extendedVersion;
114
115 if (!std::getline(iss, line))
116 {
117 log<level::ERR>("Unable to read from version",
118 entry("VERSION=%s", versionPart.c_str()));
119 return {};
120 }
121 version = line;
122
123 while (std::getline(iss, line))
124 {
125 // Each line starts with a tab, let's trim it
126 line.erase(line.begin(),
127 std::find_if(line.begin(), line.end(),
128 [](int c) { return !std::isspace(c); }));
129 ss << line << ',';
130 }
131 extendedVersion = ss.str();
132
133 // Erase the last ',', if there is one
134 if (!extendedVersion.empty())
135 {
136 extendedVersion.pop_back();
137 }
138 return {version, extendedVersion};
139}
140
Saqib Khan7f80e0b2017-10-22 11:29:07 -0500141void Delete::delete_()
142{
143 if (parent.eraseCallback)
144 {
145 parent.eraseCallback(parent.getId(parent.version()));
146 }
147}
148
149void Version::updateDeleteInterface(sdbusplus::message::message& msg)
150{
151 std::string interface, chassisState;
Patrick Williams212102e2020-05-13 17:50:50 -0500152 std::map<std::string, std::variant<std::string>> properties;
Saqib Khan7f80e0b2017-10-22 11:29:07 -0500153
154 msg.read(interface, properties);
155
156 for (const auto& p : properties)
157 {
158 if (p.first == "CurrentPowerState")
159 {
Patrick Williams550f31b2020-05-13 11:15:24 -0500160 chassisState = std::get<std::string>(p.second);
Saqib Khan7f80e0b2017-10-22 11:29:07 -0500161 }
162 }
Adriana Kobylak90fdc702018-08-29 09:38:42 -0500163 if (chassisState.empty())
164 {
165 // The chassis power state property did not change, return.
166 return;
167 }
Saqib Khan7f80e0b2017-10-22 11:29:07 -0500168
169 if ((parent.isVersionFunctional(this->versionId)) &&
170 (chassisState != CHASSIS_STATE_OFF))
171 {
172 if (deleteObject)
173 {
174 deleteObject.reset(nullptr);
175 }
176 }
177 else
178 {
179 if (!deleteObject)
180 {
181 deleteObject = std::make_unique<Delete>(bus, objPath, *this);
182 }
183 }
184}
185
Saqib Khan167601b2017-06-18 23:33:46 -0500186} // namespace updater
187} // namespace software
188} // namespace openpower