diff options
author | Ingela Anderton Andin <[email protected]> | 2014-05-12 10:04:32 +0200 |
---|---|---|
committer | Ingela Anderton Andin <[email protected]> | 2014-05-12 10:04:32 +0200 |
commit | 80a528ae9ca670cad91eccf97b385baf67b09981 (patch) | |
tree | 012d0eeddd938819bce3db6328e878e4c0bf526d /lib/ssl/src/ssl_sup.erl | |
parent | b2a3369ddb5178705f1634d9fe355696907106dc (diff) | |
parent | 441c5a4dbc01e33db11b9497c14927da1af896f6 (diff) | |
download | otp-80a528ae9ca670cad91eccf97b385baf67b09981.tar.gz otp-80a528ae9ca670cad91eccf97b385baf67b09981.tar.bz2 otp-80a528ae9ca670cad91eccf97b385baf67b09981.zip |
Merge branch 'maint'
Diffstat (limited to 'lib/ssl/src/ssl_sup.erl')
-rw-r--r-- | lib/ssl/src/ssl_sup.erl | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/lib/ssl/src/ssl_sup.erl b/lib/ssl/src/ssl_sup.erl index e1aeb11ca4..7cccf8d5a5 100644 --- a/lib/ssl/src/ssl_sup.erl +++ b/lib/ssl/src/ssl_sup.erl @@ -47,8 +47,10 @@ init([]) -> TLSConnetionManager = tls_connection_manager_child_spec(), %% Not supported yet %%DTLSConnetionManager = tls_connection_manager_child_spec(), - - {ok, {{one_for_all, 10, 3600}, [SessionCertManager, TLSConnetionManager]}}. + %% Handles emulated options so that they inherited by the accept socket, even when setopts is performed on + %% the listen socket + ListenOptionsTracker = listen_options_tracker_child_spec(), + {ok, {{one_for_all, 10, 3600}, [SessionCertManager, TLSConnetionManager, ListenOptionsTracker]}}. manager_opts() -> @@ -85,7 +87,7 @@ tls_connection_manager_child_spec() -> StartFunc = {tls_connection_sup, start_link, []}, Restart = permanent, Shutdown = 4000, - Modules = [tls_connection, ssl_connection], + Modules = [tls_connection_sup], Type = supervisor, {Name, StartFunc, Restart, Shutdown, Type, Modules}. @@ -98,6 +100,17 @@ tls_connection_manager_child_spec() -> %% Type = supervisor, %% {Name, StartFunc, Restart, Shutdown, Type, Modules}. + +listen_options_tracker_child_spec() -> + Name = ssl_socket, + StartFunc = {ssl_listen_tracker_sup, start_link, []}, + Restart = permanent, + Shutdown = 4000, + Modules = [ssl_socket], + Type = supervisor, + {Name, StartFunc, Restart, Shutdown, Type, Modules}. + + session_cb_init_args() -> case application:get_env(ssl, session_cb_init_args) of {ok, Args} when is_list(Args) -> |