selcommands: send sel entry on dbus
Send sel entry on dbus via logging service. Redfish api will get entries from dbus.
Expected event entry:
{
"@odata.id": "/redfish/v1/Systems/system/LogServices/EventLog/Entries/63",
"@odata.type": "#LogEntry.v1_9_0.LogEntry",
"AdditionalDataURI": "/redfish/v1/Systems/system/LogServices/EventLog/Entries/63/attachment",
"Created": "2018-03-14T11:34:35.178+00:00",
"EntryType": "Event",
"Id": "63",
"Message": SEL Entry Added: SEL Entry: FRU: 1, Record: Standard (0x02), Time: Fri Feb 18 16:06:25 1972\n, Sensor: THERM_THRESH_EVT (0x7D), Event Data: (010000) Limit Exceeded Assertion
"Modified": "2018-03-14T11:34:35.178+00:00",
"Name": "System Event Log Entry",
"Resolved": false,
"Severity": "OK"
}
Tested: Tested and verified on greatlakes platform.
Change-Id: Ic9584474f9bf3619f0eed95f7d19039850899c07
Signed-off-by: Delphine CC Chiu <Delphine_CC_Chiu@wiwynn.com>
diff --git a/src/selcommands.cpp b/src/selcommands.cpp
index c6f0c9b..3572269 100644
--- a/src/selcommands.cpp
+++ b/src/selcommands.cpp
@@ -1407,6 +1407,25 @@
phosphor::logging::entry("IPMISEL_MESSAGE_ID=%s", messageID.c_str()),
phosphor::logging::entry("IPMISEL_MESSAGE_ARGS=%s", logErr.c_str()));
+ std::map<std::string, std::string> ad;
+ std::string severity = "xyz.openbmc_project.Logging.Entry.Level.Critical";
+ ad.emplace("IPMI_RAW", ipmiRaw);
+
+ auto bus = sdbusplus::bus::new_default();
+ auto reqMsg = bus.new_method_call(
+ "xyz.openbmc_project.Logging", "/xyz/openbmc_project/logging",
+ "xyz.openbmc_project.Logging.Create", "Create");
+ reqMsg.append(logErr, severity, ad);
+
+ try
+ {
+ bus.call(reqMsg);
+ }
+ catch (sdbusplus::exception_t& e)
+ {
+ phosphor::logging::log<phosphor::logging::level::ERR>(e.what());
+ }
+
int responseID = selObj.addEntry(ipmiRaw.c_str());
if (responseID < 0)
{