blob: 0933505ae015dedf48fa333f9c11907522b29e3b [file] [log] [blame]
#include <sdbusplus/bus.hpp>
#include <sdbusplus/server/manager.hpp>
#include <system_error>
#include "config.h"
#include "item_updater.hpp"
#include <phosphor-logging/log.hpp>
#include "watch.hpp"
int main(int argc, char* argv[])
{
using namespace openpower::software::updater;
using namespace phosphor::logging;
auto bus = sdbusplus::bus::new_default();
sd_event* loop = nullptr;
auto rc = sd_event_default(&loop);
if (rc < 0)
{
log<level::ERR>("Error occurred during the sd_event_default",
entry("RC=%d", rc));
return -1;
}
// Add sdbusplus ObjectManager.
sdbusplus::server::manager::manager objManager(bus, SOFTWARE_OBJPATH);
ItemUpdater updater(bus, SOFTWARE_OBJPATH);
bus.request_name(BUSNAME_UPDATER);
try
{
openpower::software::updater::Watch watch(
loop,
std::bind(std::mem_fn(
&ItemUpdater::updateFunctionalAssociation),
&updater,
std::placeholders::_1));
bus.attach_event(loop, SD_EVENT_PRIORITY_NORMAL);
auto rc = sd_event_loop(loop);
if (rc < 0)
{
log<level::ERR>("Error occurred during the sd_event_loop",
entry("RC=%d", rc));
return -1;
}
}
catch (const std::system_error& e)
{
log<level::ERR>(e.what());
return -1;
}
sd_event_unref(loop);
return 0;
}