blob: f504cc7ed8e673736aad15dcb5a818ca33e66ca2 [file] [log] [blame]
Ed Tanousc9b55212017-06-12 13:25:51 -07001#include <dbus/connection.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -07002#include <dbus_monitor.hpp>
3#include <dbus_singleton.hpp>
4#include <intel_oem.hpp>
5#include <openbmc_dbus_rest.hpp>
Ed Tanousba9f9a62017-10-11 16:40:35 -07006#include <persistent_data_middleware.hpp>
Ed Tanous911ac312017-08-15 09:37:42 -07007#include <redfish_v1.hpp>
8#include <security_headers_middleware.hpp>
9#include <ssl_key_handler.hpp>
10#include <token_authorization_middleware.hpp>
11#include <web_kvm.hpp>
12#include <webassets.hpp>
Ed Tanousc4771fb2017-03-13 13:39:49 -070013#include <memory>
Ed Tanous0fdddb12017-02-28 11:06:34 -080014#include <string>
Kowalski, Kamil2b7981f2018-01-31 13:24:59 +010015#include "redfish.hpp"
Ed Tanous911ac312017-08-15 09:37:42 -070016#include <crow/app.h>
17#include <boost/asio.hpp>
Vernon Mauery168792a2018-01-26 13:42:54 -080018#include <systemd/sd-daemon.h>
Ed Tanouscc5a37f2017-05-11 10:27:23 -070019
Vernon Mauery168792a2018-01-26 13:42:54 -080020constexpr int defaultPort = 18080;
21
22template <typename... Middlewares>
23void setup_socket(crow::Crow<Middlewares...>& app) {
24 int listen_fd = sd_listen_fds(0);
25 if (1 == listen_fd) {
26 CROW_LOG_INFO << "attempting systemd socket activation";
27 if (sd_is_socket_inet(SD_LISTEN_FDS_START, AF_UNSPEC, SOCK_STREAM, 1, 0)) {
28 CROW_LOG_INFO << "Starting webserver on socket handle "
29 << SD_LISTEN_FDS_START;
30 app.socket(SD_LISTEN_FDS_START);
31 } else {
32 CROW_LOG_INFO << "bad incoming socket, starting webserver on port "
33 << defaultPort;
34 app.port(defaultPort);
35 }
36 } else {
37 CROW_LOG_INFO << "Starting webserver on port " << defaultPort;
38 app.port(defaultPort);
39 }
40}
41
Ed Tanous99923322017-03-03 14:21:24 -080042int main(int argc, char** argv) {
Ed Tanous3dac7492017-08-02 13:46:20 -070043 auto io = std::make_shared<boost::asio::io_service>();
Kowalski, Kamil2b7981f2018-01-31 13:24:59 +010044 crow::PersistentData::session_store =
45 std::make_shared<crow::PersistentData::SessionStore>();
Ed Tanousba9f9a62017-10-11 16:40:35 -070046 crow::App<crow::PersistentData::Middleware,
47 crow::TokenAuthorization::Middleware,
Ed Tanous911ac312017-08-15 09:37:42 -070048 crow::SecurityHeadersMiddleware>
Ed Tanous3dac7492017-08-02 13:46:20 -070049 app(io);
Ed Tanousb4d29f42017-03-24 16:39:25 -070050
Ed Tanous911ac312017-08-15 09:37:42 -070051#ifdef CROW_ENABLE_SSL
52 std::string ssl_pem_file("server.pem");
Ed Tanous4d92cbf2017-06-22 15:41:02 -070053 std::cout << "Building SSL context\n";
Ed Tanous4758d5b2017-06-06 15:28:13 -070054
Ed Tanous911ac312017-08-15 09:37:42 -070055 ensuressl::ensure_openssl_key_present_and_valid(ssl_pem_file);
56 std::cout << "SSL Enabled\n";
57 auto ssl_context = ensuressl::get_ssl_context(ssl_pem_file);
58 app.ssl(std::move(ssl_context));
59#endif
60 // Static assets need to be initialized before Authorization, because auth
61 // needs to build the whitelist from the static routes
62 crow::webassets::request_routes(app);
63 crow::TokenAuthorization::request_routes(app);
Ed Tanousf0226cd2017-05-16 12:35:38 -070064
Ed Tanous911ac312017-08-15 09:37:42 -070065 crow::kvm::request_routes(app);
66 crow::redfish::request_routes(app);
67 crow::dbus_monitor::request_routes(app);
68 crow::intel_oem::request_routes(app);
69 crow::openbmc_mapper::request_routes(app);
70
71 crow::logger::setLogLevel(crow::LogLevel::INFO);
Vernon Mauery168792a2018-01-26 13:42:54 -080072
73 CROW_LOG_INFO << "bmcweb (" << __DATE__ << ": " << __TIME__ << ')';
74 setup_socket(app);
Ed Tanous3dac7492017-08-02 13:46:20 -070075
76 // Start dbus connection
Ed Tanous911ac312017-08-15 09:37:42 -070077 crow::connections::system_bus =
78 std::make_shared<dbus::connection>(*io, dbus::bus::system);
Ed Tanous3dac7492017-08-02 13:46:20 -070079
Borawski.Lukaszb6df6dc2018-01-24 10:20:45 +010080 redfish::RedfishService redfish(app);
81
Ed Tanous4758d5b2017-06-06 15:28:13 -070082 app.run();
Ed Tanous0fdddb12017-02-28 11:06:34 -080083}