63 {
65
66 using SocketServer = apps::echo::model::STREAM::EchoSocketServer;
67 const SocketServer server = apps::echo::model::STREAM::getServer();
68
69#if (STREAM_TYPE == TLS)
70 std::string cert = "/home/voc/projects/snodec/snode.c/certs/snode.c_-_server.pem";
71 std::string key = "/home/voc/projects/snodec/snode.c/certs/Volker_Christian_-_Web_-_snode.c_-_server.key.encrypted.pem";
72 std::string pass = "snode.c";
73
74 std::map<std::string, std::map<std::string, std::variant<std::string, bool, ssl_option_t>>> sniCerts = {
75 {"snodec.home.vchrist.at", {{"Cert", cert}, {"CertKey", key}, {"CertKeyPassword", pass}}},
76 {"www.vchrist.at", {{"Cert", cert}, {"CertKey", key}, {"CertKeyPassword", pass}}}};
77
78 server.getConfig().addSniCerts(sniCerts);
79#endif
80
81
82
83
84 server.listen([instanceName = server.getConfig().getInstanceName()](const SocketServer::SocketAddress& socketAddress,
86 switch (state) {
87 case core::socket::State::OK:
88 VLOG(1) << instanceName << ": listening on '" << socketAddress.toString() << "'";
89 break;
90 case core::socket::State::DISABLED:
91 VLOG(1) << instanceName << ": disabled";
92 break;
93 case core::socket::State::ERROR:
94 LOG(ERROR) << instanceName << ": " << socketAddress.toString() << ": " << state.what();
95 break;
96 case core::socket::State::FATAL:
97 LOG(FATAL) << instanceName << ": " << socketAddress.toString() << ": " << state.what();
98 break;
99 }
100 });
101
103}
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