aboutsummaryrefslogtreecommitdiffstats
path: root/src/lib/tls/tls_server.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/tls/tls_server.cpp')
-rw-r--r--src/lib/tls/tls_server.cpp16
1 files changed, 11 insertions, 5 deletions
diff --git a/src/lib/tls/tls_server.cpp b/src/lib/tls/tls_server.cpp
index 5eccec2a7..2e546eab1 100644
--- a/src/lib/tls/tls_server.cpp
+++ b/src/lib/tls/tls_server.cpp
@@ -242,13 +242,11 @@ Server::Server(Callbacks& callbacks,
Credentials_Manager& creds,
const Policy& policy,
RandomNumberGenerator& rng,
- next_protocol_fn next_proto,
bool is_datagram,
size_t io_buf_sz) :
Channel(callbacks, session_manager, rng, policy,
is_datagram, io_buf_sz),
- m_creds(creds),
- m_choose_next_protocol(next_proto)
+ m_creds(creds)
{
}
@@ -419,8 +417,16 @@ void Server::process_client_hello_msg(const Handshake_State* active_state,
catch(...) {}
m_next_protocol = "";
- if(m_choose_next_protocol && pending_state.client_hello()->supports_alpn())
- m_next_protocol = m_choose_next_protocol(pending_state.client_hello()->next_protocols());
+ if(pending_state.client_hello()->supports_alpn())
+ {
+ m_next_protocol = callbacks().tls_server_choose_app_protocol(pending_state.client_hello()->next_protocols());
+
+ // if the callback return was empty, fall back to the (deprecated) std::function
+ if(m_next_protocol.empty() && m_choose_next_protocol)
+ {
+ m_next_protocol = m_choose_next_protocol(pending_state.client_hello()->next_protocols());
+ }
+ }
if(resuming)
{