| #include <bmcweb_config.h> |
| #include <systemd/sd-daemon.h> |
| |
| #include <app.hpp> |
| #include <boost/asio/io_context.hpp> |
| #include <cors_preflight.hpp> |
| #include <dbus_monitor.hpp> |
| #include <dbus_singleton.hpp> |
| #include <google/google_service_root.hpp> |
| #include <hostname_monitor.hpp> |
| #include <ibm/management_console_rest.hpp> |
| #include <image_upload.hpp> |
| #include <kvm_websocket.hpp> |
| #include <login_routes.hpp> |
| #include <obmc_console.hpp> |
| #include <openbmc_dbus_rest.hpp> |
| #include <redfish.hpp> |
| #include <redfish_v1.hpp> |
| #include <sdbusplus/asio/connection.hpp> |
| #include <sdbusplus/bus.hpp> |
| #include <sdbusplus/server.hpp> |
| #include <security_headers.hpp> |
| #include <ssl_key_handler.hpp> |
| #include <vm_websocket.hpp> |
| #include <webassets.hpp> |
| |
| #include <memory> |
| #include <string> |
| |
| #ifdef BMCWEB_ENABLE_VM_NBDPROXY |
| #include <nbd_proxy.hpp> |
| #endif |
| |
| constexpr int defaultPort = 18080; |
| |
| inline void setupSocket(crow::App& app) |
| { |
| int listenFd = sd_listen_fds(0); |
| if (1 == listenFd) |
| { |
| BMCWEB_LOG_INFO << "attempting systemd socket activation"; |
| if (sd_is_socket_inet(SD_LISTEN_FDS_START, AF_UNSPEC, SOCK_STREAM, 1, |
| 0) != 0) |
| { |
| BMCWEB_LOG_INFO << "Starting webserver on socket handle " |
| << SD_LISTEN_FDS_START; |
| app.socket(SD_LISTEN_FDS_START); |
| } |
| else |
| { |
| BMCWEB_LOG_INFO |
| << "bad incoming socket, starting webserver on port " |
| << defaultPort; |
| app.port(defaultPort); |
| } |
| } |
| else |
| { |
| BMCWEB_LOG_INFO << "Starting webserver on port " << defaultPort; |
| app.port(defaultPort); |
| } |
| } |
| |
| int run() |
| { |
| crow::Logger::setLogLevel(crow::LogLevel::Debug); |
| |
| auto io = std::make_shared<boost::asio::io_context>(); |
| App app(io); |
| |
| crow::connections::systemBus = |
| std::make_shared<sdbusplus::asio::connection>(*io); |
| |
| // Static assets need to be initialized before Authorization, because auth |
| // needs to build the whitelist from the static routes |
| |
| #ifdef BMCWEB_ENABLE_STATIC_HOSTING |
| crow::webassets::requestRoutes(app); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_KVM |
| crow::obmc_kvm::requestRoutes(app); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_REDFISH |
| redfish::requestRoutes(app); |
| redfish::RedfishService redfish(app); |
| |
| // Create EventServiceManager instance and initialize Config |
| redfish::EventServiceManager::getInstance(); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_DBUS_REST |
| crow::dbus_monitor::requestRoutes(app); |
| crow::image_upload::requestRoutes(app); |
| crow::openbmc_mapper::requestRoutes(app); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_HOST_SERIAL_WEBSOCKET |
| crow::obmc_console::requestRoutes(app); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_VM_WEBSOCKET |
| crow::obmc_vm::requestRoutes(app); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_IBM_MANAGEMENT_CONSOLE |
| crow::ibm_mc::requestRoutes(app); |
| crow::ibm_mc_lock::Lock::getInstance(); |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_GOOGLE_API |
| crow::google_api::requestRoutes(app); |
| #endif |
| |
| if (bmcwebInsecureDisableXssPrevention != 0) |
| { |
| cors_preflight::requestRoutes(app); |
| } |
| |
| crow::login_routes::requestRoutes(app); |
| |
| setupSocket(app); |
| |
| #ifdef BMCWEB_ENABLE_VM_NBDPROXY |
| crow::nbd_proxy::requestRoutes(app); |
| #endif |
| |
| #ifndef BMCWEB_ENABLE_REDFISH_DBUS_LOG_ENTRIES |
| int rc = redfish::EventServiceManager::startEventLogMonitor(*io); |
| if (rc != 0) |
| { |
| BMCWEB_LOG_ERROR << "Redfish event handler setup failed..."; |
| return rc; |
| } |
| #endif |
| |
| #ifdef BMCWEB_ENABLE_SSL |
| BMCWEB_LOG_INFO << "Start Hostname Monitor Service..."; |
| crow::hostname_monitor::registerHostnameSignal(); |
| #endif |
| |
| app.run(); |
| io->run(); |
| |
| crow::connections::systemBus.reset(); |
| return 0; |
| } |
| |
| int main(int /*argc*/, char** /*argv*/) |
| { |
| try |
| { |
| return run(); |
| } |
| catch (...) |
| { |
| return -1; |
| BMCWEB_LOG_CRITICAL << "Threw exception to main"; |
| } |
| } |