blob: f49b25d0ce00c2f142e57ccb60cdd8a3f9dbbfc5 [file] [log] [blame]
Ed Tanous2205bbf2021-06-17 13:33:47 -07001#include <bmcweb_config.h>
Ed Tanous9e6e1b22018-03-16 13:08:50 -07002#include <systemd/sd-daemon.h>
Ed Tanous1abe55e2018-09-05 08:30:59 -07003
Ed Tanous04e438c2020-10-03 08:06:26 -07004#include <app.hpp>
Ed Tanous8f626352018-12-19 14:51:54 -08005#include <boost/asio/io_context.hpp>
Ed Tanous0260d9d2021-02-07 19:31:07 +00006#include <cors_preflight.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -07007#include <dbus_monitor.hpp>
8#include <dbus_singleton.hpp>
Feras Aldahlawi735ef6d2021-03-19 14:01:46 -07009#include <google/google_service_root.hpp>
Alan Kuoa8220702020-11-26 11:15:29 +080010#include <hostname_monitor.hpp>
Ed Tanous02379d32020-09-15 21:15:44 -070011#include <ibm/management_console_rest.hpp>
Ed Tanousc3ee5222018-05-01 12:58:27 -070012#include <image_upload.hpp>
Ed Tanous3eb2f352018-12-20 12:30:45 -080013#include <kvm_websocket.hpp>
James Feist3909dc82020-04-03 10:58:55 -070014#include <login_routes.hpp>
Ed Tanous77295132018-10-12 11:11:17 -070015#include <obmc_console.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -070016#include <openbmc_dbus_rest.hpp>
Ed Tanous1e439872018-05-18 11:48:52 -070017#include <redfish.hpp>
Carson Labrado7fb33562022-04-18 23:26:56 +000018#include <redfish_aggregator.hpp>
Ed Tanousaa2e59c2018-04-12 12:17:20 -070019#include <sdbusplus/asio/connection.hpp>
20#include <sdbusplus/bus.hpp>
21#include <sdbusplus/server.hpp>
Ed Tanous52cc1122020-07-18 13:51:21 -070022#include <security_headers.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -070023#include <ssl_key_handler.hpp>
Adriana Kobylak1bfbe0e2019-01-17 12:08:38 -060024#include <vm_websocket.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -070025#include <webassets.hpp>
Ed Tanouscc5a37f2017-05-11 10:27:23 -070026
Ed Tanous02379d32020-09-15 21:15:44 -070027#include <memory>
Gunnar Mills1214b7e2020-06-04 10:11:30 -050028#include <string>
29
Iwona Klimaszewskac0a1c8a2019-07-12 18:26:38 +020030#ifdef BMCWEB_ENABLE_VM_NBDPROXY
31#include <nbd_proxy.hpp>
32#endif
33
Vernon Mauery168792a2018-01-26 13:42:54 -080034constexpr int defaultPort = 18080;
35
Ed Tanous23a21a12020-07-25 04:45:05 +000036inline void setupSocket(crow::App& app)
Ed Tanous1abe55e2018-09-05 08:30:59 -070037{
38 int listenFd = sd_listen_fds(0);
39 if (1 == listenFd)
40 {
41 BMCWEB_LOG_INFO << "attempting systemd socket activation";
42 if (sd_is_socket_inet(SD_LISTEN_FDS_START, AF_UNSPEC, SOCK_STREAM, 1,
Ed Tanouse662eae2022-01-25 10:39:19 -080043 0) != 0)
Ed Tanous1abe55e2018-09-05 08:30:59 -070044 {
45 BMCWEB_LOG_INFO << "Starting webserver on socket handle "
46 << SD_LISTEN_FDS_START;
47 app.socket(SD_LISTEN_FDS_START);
48 }
49 else
50 {
51 BMCWEB_LOG_INFO
52 << "bad incoming socket, starting webserver on port "
53 << defaultPort;
54 app.port(defaultPort);
55 }
Vernon Mauery168792a2018-01-26 13:42:54 -080056 }
Ed Tanous1abe55e2018-09-05 08:30:59 -070057 else
58 {
59 BMCWEB_LOG_INFO << "Starting webserver on port " << defaultPort;
60 app.port(defaultPort);
61 }
Vernon Mauery168792a2018-01-26 13:42:54 -080062}
63
Ed Tanous2119e272022-02-17 18:07:14 -080064static int run()
Ed Tanous1abe55e2018-09-05 08:30:59 -070065{
Ed Tanouseb643c22020-10-02 14:51:22 -070066 crow::Logger::setLogLevel(crow::LogLevel::Debug);
Lewanczyk, Dawid08777fb2018-03-22 23:33:49 +010067
Ed Tanous8f626352018-12-19 14:51:54 -080068 auto io = std::make_shared<boost::asio::io_context>();
Ed Tanous52cc1122020-07-18 13:51:21 -070069 App app(io);
Ed Tanousb4d29f42017-03-24 16:39:25 -070070
AppaRao Pulif6f97192021-03-23 23:36:40 +000071 crow::connections::systemBus =
72 std::make_shared<sdbusplus::asio::connection>(*io);
73
Ed Tanous1abe55e2018-09-05 08:30:59 -070074 // Static assets need to be initialized before Authorization, because auth
75 // needs to build the whitelist from the static routes
Ed Tanousf0226cd2017-05-16 12:35:38 -070076
Andrew Geisslerd529ee22018-08-10 13:49:54 -070077#ifdef BMCWEB_ENABLE_STATIC_HOSTING
Ed Tanous1abe55e2018-09-05 08:30:59 -070078 crow::webassets::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -070079#endif
80
81#ifdef BMCWEB_ENABLE_KVM
Ed Tanous3eb2f352018-12-20 12:30:45 -080082 crow::obmc_kvm::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -070083#endif
84
85#ifdef BMCWEB_ENABLE_REDFISH
P Dheeraj Srujan Kumarb614e2b2021-02-05 01:51:15 +053086 redfish::RedfishService redfish(app);
87
Carson Labrado7fb33562022-04-18 23:26:56 +000088 // Create HttpClient instance and initialize Config
89 crow::HttpClient::getInstance();
90
P Dheeraj Srujan Kumarb614e2b2021-02-05 01:51:15 +053091 // Create EventServiceManager instance and initialize Config
92 redfish::EventServiceManager::getInstance();
Carson Labrado7fb33562022-04-18 23:26:56 +000093
94#ifdef BMCWEB_ENABLE_REDFISH_AGGREGATION
95 // Create RedfishAggregator instance and initialize Config
96 redfish::RedfishAggregator::getInstance();
97#endif
Ed Tanous1e439872018-05-18 11:48:52 -070098#endif
99
100#ifdef BMCWEB_ENABLE_DBUS_REST
Ed Tanous1abe55e2018-09-05 08:30:59 -0700101 crow::dbus_monitor::requestRoutes(app);
102 crow::image_upload::requestRoutes(app);
103 crow::openbmc_mapper::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -0700104#endif
105
Ed Tanous77295132018-10-12 11:11:17 -0700106#ifdef BMCWEB_ENABLE_HOST_SERIAL_WEBSOCKET
107 crow::obmc_console::requestRoutes(app);
108#endif
109
Adriana Kobylak1bfbe0e2019-01-17 12:08:38 -0600110#ifdef BMCWEB_ENABLE_VM_WEBSOCKET
111 crow::obmc_vm::requestRoutes(app);
112#endif
113
Ratan Gupta453fed02019-12-14 09:39:47 +0530114#ifdef BMCWEB_ENABLE_IBM_MANAGEMENT_CONSOLE
115 crow::ibm_mc::requestRoutes(app);
Ratan Gupta07386c62019-12-14 14:06:09 +0530116 crow::ibm_mc_lock::Lock::getInstance();
Ratan Gupta453fed02019-12-14 09:39:47 +0530117#endif
118
Feras Aldahlawi735ef6d2021-03-19 14:01:46 -0700119#ifdef BMCWEB_ENABLE_GOOGLE_API
120 crow::google_api::requestRoutes(app);
121#endif
122
Ed Tanouse662eae2022-01-25 10:39:19 -0800123 if (bmcwebInsecureDisableXssPrevention != 0)
Ed Tanous0260d9d2021-02-07 19:31:07 +0000124 {
125 cors_preflight::requestRoutes(app);
126 }
Ed Tanous52cc1122020-07-18 13:51:21 -0700127
James Feist3909dc82020-04-03 10:58:55 -0700128 crow::login_routes::requestRoutes(app);
Ed Tanous911ac312017-08-15 09:37:42 -0700129
Ed Tanous1abe55e2018-09-05 08:30:59 -0700130 setupSocket(app);
Ed Tanous3dac7492017-08-02 13:46:20 -0700131
Iwona Klimaszewskac0a1c8a2019-07-12 18:26:38 +0200132#ifdef BMCWEB_ENABLE_VM_NBDPROXY
133 crow::nbd_proxy::requestRoutes(app);
134#endif
135
AppaRao Puli7f4eb582020-06-13 19:01:29 +0530136#ifndef BMCWEB_ENABLE_REDFISH_DBUS_LOG_ENTRIES
137 int rc = redfish::EventServiceManager::startEventLogMonitor(*io);
Ed Tanouse662eae2022-01-25 10:39:19 -0800138 if (rc != 0)
AppaRao Puli7f4eb582020-06-13 19:01:29 +0530139 {
140 BMCWEB_LOG_ERROR << "Redfish event handler setup failed...";
141 return rc;
142 }
143#endif
144
Alan Kuoa8220702020-11-26 11:15:29 +0800145#ifdef BMCWEB_ENABLE_SSL
146 BMCWEB_LOG_INFO << "Start Hostname Monitor Service...";
147 crow::hostname_monitor::registerHostnameSignal();
148#endif
149
Ed Tanous1abe55e2018-09-05 08:30:59 -0700150 app.run();
151 io->run();
Ed Tanousaa2e59c2018-04-12 12:17:20 -0700152
Ed Tanous1abe55e2018-09-05 08:30:59 -0700153 crow::connections::systemBus.reset();
P Dheeraj Srujan Kumar85bf8902021-07-12 21:07:36 +0530154 return 0;
Ed Tanous0fdddb12017-02-28 11:06:34 -0800155}
Ed Tanous24b2fe82022-01-06 12:45:54 -0800156
157int main(int /*argc*/, char** /*argv*/)
158{
159 try
160 {
161 return run();
162 }
163 catch (...)
164 {
165 return -1;
166 BMCWEB_LOG_CRITICAL << "Threw exception to main";
167 }
168}