blob: 4702d627289f46054c82db90dda58ce87569683e [file] [log] [blame]
#include "main.hpp"
#include "comm_module.hpp"
#include "command/guid.hpp"
#include "command_table.hpp"
#include "message.hpp"
#include "message_handler.hpp"
#include "sd_event_loop.hpp"
#include "sessions_manager.hpp"
#include "socket_channel.hpp"
#include "sol_module.hpp"
#include <assert.h>
#include <dirent.h>
#include <dlfcn.h>
#include <ipmid/api.h>
#include <systemd/sd-daemon.h>
#include <systemd/sd-event.h>
#include <unistd.h>
#include <CLI/CLI.hpp>
#include <phosphor-logging/lg2.hpp>
#include <sdbusplus/asio/connection.hpp>
#include <user_channel/channel_layer.hpp>
#include <tuple>
static auto io = std::make_shared<boost::asio::io_context>();
std::shared_ptr<boost::asio::io_context> getIo()
{
return io;
}
sd_bus* bus = nullptr;
std::shared_ptr<sdbusplus::asio::connection> sdbusp;
/*
* @brief Required by apphandler IPMI Provider Library
*/
sd_bus* ipmid_get_sd_bus_connection()
{
return bus;
}
/*
* @brief mechanism to get at sdbusplus object
*/
std::shared_ptr<sdbusplus::asio::connection> getSdBus()
{
return sdbusp;
}
static EInterfaceIndex currentInterfaceIndex = interfaceUnknown;
static void setInterfaceIndex(const std::string& channel)
{
try
{
currentInterfaceIndex =
static_cast<EInterfaceIndex>(ipmi::getChannelByName(channel));
}
catch (const std::exception& e)
{
lg2::error("Requested {NAME} is not a valid channel name: {ERROR}",
"NAME", channel, "ERROR", e);
}
}
EInterfaceIndex getInterfaceIndex(void)
{
return currentInterfaceIndex;
}
int main(int argc, char* argv[])
{
CLI::App app("KCS RMCP+ bridge");
std::string channel;
app.add_option("-c,--channel", channel, "channel name. e.g., eth0");
uint16_t port = ipmi::rmcpp::defaultPort;
app.add_option("-p,--port", port, "port number");
bool verbose = false;
app.add_option("-v,--verbose", verbose, "print more verbose output");
CLI11_PARSE(app, argc, argv);
// Connect to system bus
auto rc = sd_bus_default_system(&bus);
if (rc < 0)
{
lg2::error("Failed to connect to system bus: {ERROR}", "ERROR",
strerror(-rc));
return rc;
}
sdbusp = std::make_shared<sdbusplus::asio::connection>(*io, bus);
ipmi::ipmiChannelInit();
if (channel.size())
{
setInterfaceIndex(channel);
}
session::Manager::get().managerInit(channel);
// Register callback to update cache for a GUID change and cache the GUID
command::registerGUIDChangeCallback();
// Register callback to update cache for sol conf change
sol::registerSolConfChangeCallbackHandler(channel);
// Register the phosphor-net-ipmid session setup commands
command::sessionSetupCommands();
// Register the phosphor-net-ipmid SOL commands
sol::command::registerCommands();
auto& loop = eventloop::EventLoop::get();
if (loop.setupSocket(sdbusp, channel))
{
return EXIT_FAILURE;
}
// Start Event Loop
return loop.startEventLoop();
}