blob: 0962bda8f1a09f74d8f18ce19141d554fd24f10e [file] [log] [blame]
#include "config.h"
#include "scheduled_host_transition.hpp"
#include <getopt.h>
#include <sdbusplus/bus.hpp>
#include <cstdlib>
#include <exception>
#include <filesystem>
int main(int argc, char** argv)
{
size_t hostId = 0;
int arg;
int optIndex = 0;
static struct option longOpts[] = {{"host", required_argument, 0, 'h'},
{0, 0, 0, 0}};
while ((arg = getopt_long(argc, argv, "h:", longOpts, &optIndex)) != -1)
{
switch (arg)
{
case 'h':
hostId = std::stoul(optarg);
break;
default:
break;
}
}
namespace fs = std::filesystem;
// Get a default event loop
auto event = sdeventplus::Event::get_default();
// Get a handle to system dbus
auto bus = sdbusplus::bus::new_default();
// For now, we only have one instance of the host
auto objPathInst = std::string{HOST_OBJPATH} + std::to_string(hostId);
// Check SCHEDULED_HOST_TRANSITION_PERSIST_PATH
auto dir = fs::path(SCHEDULED_HOST_TRANSITION_PERSIST_PATH).parent_path();
if (!fs::exists(dir))
{
fs::create_directories(dir);
}
// Add sdbusplus ObjectManager.
sdbusplus::server::manager_t objManager(bus, objPathInst.c_str());
phosphor::state::manager::ScheduledHostTransition manager(
bus, objPathInst.c_str(), hostId, event);
// For backwards compatibility, request a busname without host id if
// input id is 0.
if (hostId == 0)
{
bus.request_name(SCHEDULED_HOST_TRANSITION_BUSNAME);
}
bus.request_name((std::string{SCHEDULED_HOST_TRANSITION_BUSNAME} +
std::to_string(hostId))
.c_str());
// Attach the bus to sd_event to service user requests
bus.attach_event(event.get(), SD_EVENT_PRIORITY_NORMAL);
event.loop();
return 0;
}