blob: b626f5b0a25b7858e206282183126e39f9077905 [file] [log] [blame]
Ed Tanousc94ad492019-10-10 15:39:33 -07001#include <app.h>
Ed Tanous9e6e1b22018-03-16 13:08:50 -07002#include <systemd/sd-daemon.h>
Ed Tanous1abe55e2018-09-05 08:30:59 -07003
Ed Tanous8f626352018-12-19 14:51:54 -08004#include <boost/asio/io_context.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -07005#include <dbus_monitor.hpp>
6#include <dbus_singleton.hpp>
Ed Tanousc3ee5222018-05-01 12:58:27 -07007#include <image_upload.hpp>
Ed Tanous3eb2f352018-12-20 12:30:45 -08008#include <kvm_websocket.hpp>
James Feist3909dc82020-04-03 10:58:55 -07009#include <login_routes.hpp>
Ed Tanous77295132018-10-12 11:11:17 -070010#include <obmc_console.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -070011#include <openbmc_dbus_rest.hpp>
Gunnar Mills1214b7e2020-06-04 10:11:30 -050012
13#include <memory>
Ratan Gupta453fed02019-12-14 09:39:47 +053014#ifdef BMCWEB_ENABLE_IBM_MANAGEMENT_CONSOLE
15#include <ibm/management_console_rest.hpp>
16#endif
Ed Tanous1e439872018-05-18 11:48:52 -070017#include <redfish.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -070018#include <redfish_v1.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
Gunnar Mills1214b7e2020-06-04 10:11:30 -050027#include <string>
28
Iwona Klimaszewskac0a1c8a2019-07-12 18:26:38 +020029#ifdef BMCWEB_ENABLE_VM_NBDPROXY
30#include <nbd_proxy.hpp>
31#endif
32
Vernon Mauery168792a2018-01-26 13:42:54 -080033constexpr int defaultPort = 18080;
34
Ed Tanous23a21a12020-07-25 04:45:05 +000035inline void setupSocket(crow::App& app)
Ed Tanous1abe55e2018-09-05 08:30:59 -070036{
37 int listenFd = sd_listen_fds(0);
38 if (1 == listenFd)
39 {
40 BMCWEB_LOG_INFO << "attempting systemd socket activation";
41 if (sd_is_socket_inet(SD_LISTEN_FDS_START, AF_UNSPEC, SOCK_STREAM, 1,
42 0))
43 {
44 BMCWEB_LOG_INFO << "Starting webserver on socket handle "
45 << SD_LISTEN_FDS_START;
46 app.socket(SD_LISTEN_FDS_START);
47 }
48 else
49 {
50 BMCWEB_LOG_INFO
51 << "bad incoming socket, starting webserver on port "
52 << defaultPort;
53 app.port(defaultPort);
54 }
Vernon Mauery168792a2018-01-26 13:42:54 -080055 }
Ed Tanous1abe55e2018-09-05 08:30:59 -070056 else
57 {
58 BMCWEB_LOG_INFO << "Starting webserver on port " << defaultPort;
59 app.port(defaultPort);
60 }
Vernon Mauery168792a2018-01-26 13:42:54 -080061}
62
Ed Tanous1abe55e2018-09-05 08:30:59 -070063int main(int argc, char** argv)
64{
Ed Tanous271584a2019-07-09 16:24:22 -070065 crow::logger::setLogLevel(crow::LogLevel::Debug);
Lewanczyk, Dawid08777fb2018-03-22 23:33:49 +010066
Ed Tanous8f626352018-12-19 14:51:54 -080067 auto io = std::make_shared<boost::asio::io_context>();
Ed Tanous52cc1122020-07-18 13:51:21 -070068 App app(io);
Ed Tanousb4d29f42017-03-24 16:39:25 -070069
Ed Tanous1abe55e2018-09-05 08:30:59 -070070 // Static assets need to be initialized before Authorization, because auth
71 // needs to build the whitelist from the static routes
Ed Tanousf0226cd2017-05-16 12:35:38 -070072
Andrew Geisslerd529ee22018-08-10 13:49:54 -070073#ifdef BMCWEB_ENABLE_STATIC_HOSTING
Ed Tanous1abe55e2018-09-05 08:30:59 -070074 crow::webassets::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -070075#endif
76
77#ifdef BMCWEB_ENABLE_KVM
Ed Tanous3eb2f352018-12-20 12:30:45 -080078 crow::obmc_kvm::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -070079#endif
80
81#ifdef BMCWEB_ENABLE_REDFISH
Ed Tanous1abe55e2018-09-05 08:30:59 -070082 crow::redfish::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -070083#endif
84
85#ifdef BMCWEB_ENABLE_DBUS_REST
Ed Tanous1abe55e2018-09-05 08:30:59 -070086 crow::dbus_monitor::requestRoutes(app);
87 crow::image_upload::requestRoutes(app);
88 crow::openbmc_mapper::requestRoutes(app);
Ed Tanous1e439872018-05-18 11:48:52 -070089#endif
90
Ed Tanous77295132018-10-12 11:11:17 -070091#ifdef BMCWEB_ENABLE_HOST_SERIAL_WEBSOCKET
92 crow::obmc_console::requestRoutes(app);
93#endif
94
Adriana Kobylak1bfbe0e2019-01-17 12:08:38 -060095#ifdef BMCWEB_ENABLE_VM_WEBSOCKET
96 crow::obmc_vm::requestRoutes(app);
97#endif
98
Ratan Gupta453fed02019-12-14 09:39:47 +053099#ifdef BMCWEB_ENABLE_IBM_MANAGEMENT_CONSOLE
100 crow::ibm_mc::requestRoutes(app);
Ratan Gupta07386c62019-12-14 14:06:09 +0530101 crow::ibm_mc_lock::Lock::getInstance();
Ratan Gupta453fed02019-12-14 09:39:47 +0530102#endif
103
Ed Tanous52cc1122020-07-18 13:51:21 -0700104#ifdef BMCWEB_INSECURE_DISABLE_XSS_PREVENTION
105 cors_preflight::requestRoutes(app);
106#endif
107
James Feist3909dc82020-04-03 10:58:55 -0700108 crow::login_routes::requestRoutes(app);
Ed Tanous911ac312017-08-15 09:37:42 -0700109
Ed Tanous1abe55e2018-09-05 08:30:59 -0700110 setupSocket(app);
Ed Tanous3dac7492017-08-02 13:46:20 -0700111
Ed Tanous1abe55e2018-09-05 08:30:59 -0700112 crow::connections::systemBus =
113 std::make_shared<sdbusplus::asio::connection>(*io);
Iwona Klimaszewskac0a1c8a2019-07-12 18:26:38 +0200114
115#ifdef BMCWEB_ENABLE_VM_NBDPROXY
116 crow::nbd_proxy::requestRoutes(app);
117#endif
118
Ed Tanous1abe55e2018-09-05 08:30:59 -0700119 redfish::RedfishService redfish(app);
Borawski.Lukaszb6df6dc2018-01-24 10:20:45 +0100120
AppaRao Puli7f4eb582020-06-13 19:01:29 +0530121#ifndef BMCWEB_ENABLE_REDFISH_DBUS_LOG_ENTRIES
122 int rc = redfish::EventServiceManager::startEventLogMonitor(*io);
123 if (rc)
124 {
125 BMCWEB_LOG_ERROR << "Redfish event handler setup failed...";
126 return rc;
127 }
128#endif
129
Ed Tanous1abe55e2018-09-05 08:30:59 -0700130 app.run();
131 io->run();
Ed Tanousaa2e59c2018-04-12 12:17:20 -0700132
Ed Tanous1abe55e2018-09-05 08:30:59 -0700133 crow::connections::systemBus.reset();
Ed Tanous0fdddb12017-02-28 11:06:34 -0800134}