41 {
43
44 using SocketServer = apps::echo::model::STREAM::EchoSocketServer;
45 const SocketServer server = apps::echo::model::STREAM::getServer();
46
47#if (STREAM_TYPE == TLS)
48 std::string cert = "/home/voc/projects/snodec/snode.c/certs/snode.c_-_server.pem";
49 std::string key = "/home/voc/projects/snodec/snode.c/certs/Volker_Christian_-_Web_-_snode.c_-_server.key.encrypted.pem";
50 std::string pass = "snode.c";
51
52 std::map<std::string, std::map<std::string, std::variant<std::string, bool, ssl_option_t>>> sniCerts = {
53 {"snodec.home.vchrist.at", {{"Cert", cert}, {"CertKey", key}, {"CertKeyPassword", pass}}},
54 {"www.vchrist.at", {{"Cert", cert}, {"CertKey", key}, {"CertKeyPassword", pass}}}};
55
56 server.getConfig().addSniCerts(sniCerts);
57#endif
58
59
60
61
62 server.listen([instanceName = server.getConfig().getInstanceName()](const SocketServer::SocketAddress& socketAddress,
64 switch (state) {
65 case core::socket::State::OK:
66 VLOG(1) << instanceName << ": listening on '" << socketAddress.toString() << "'";
67 break;
68 case core::socket::State::DISABLED:
69 VLOG(1) << instanceName << ": disabled";
70 break;
71 case core::socket::State::ERROR:
72 LOG(ERROR) << instanceName << ": " << socketAddress.toString() << ": " << state.what();
73 break;
74 case core::socket::State::FATAL:
75 LOG(FATAL) << instanceName << ": " << socketAddress.toString() << ": " << state.what();
76 break;
77 }
78 });
79
81}
static void init(int argc, char *argv[])
static int start(const utils::Timeval &timeOut={LONG_MAX, 0})
net::in::stream::SocketServer< core::socket::stream::legacy::SocketAcceptor, net::in::stream::legacy::config::ConfigSocketServer, SocketContextFactoryT, Args... > SocketServer