aboutsummaryrefslogtreecommitdiffstats
path: root/lib/ssl/src/tls_connection_sup.erl
diff options
context:
space:
mode:
authorIngela Anderton Andin <[email protected]>2013-12-02 10:24:56 +0100
committerIngela Anderton Andin <[email protected]>2013-12-02 10:24:56 +0100
commitc3d9d667e028284d6f96f8e260d094f1775182ea (patch)
treef88229efc098d69e798132acc540835e11e24571 /lib/ssl/src/tls_connection_sup.erl
parentf2fc6a63429f0c7945e7644e5fe3d8ee265bd28f (diff)
parent239ce1c4781fe4fc25c55795573654453887f507 (diff)
downloadotp-c3d9d667e028284d6f96f8e260d094f1775182ea.tar.gz
otp-c3d9d667e028284d6f96f8e260d094f1775182ea.tar.bz2
otp-c3d9d667e028284d6f96f8e260d094f1775182ea.zip
Merge branch 'maint'
Diffstat (limited to 'lib/ssl/src/tls_connection_sup.erl')
-rw-r--r--lib/ssl/src/tls_connection_sup.erl66
1 files changed, 66 insertions, 0 deletions
diff --git a/lib/ssl/src/tls_connection_sup.erl b/lib/ssl/src/tls_connection_sup.erl
new file mode 100644
index 0000000000..6f0d8a7262
--- /dev/null
+++ b/lib/ssl/src/tls_connection_sup.erl
@@ -0,0 +1,66 @@
+%%
+%% %CopyrightBegin%
+%%
+%% Copyright Ericsson AB 2007-2013. All Rights Reserved.
+%%
+%% The contents of this file are subject to the Erlang Public License,
+%% Version 1.1, (the "License"); you may not use this file except in
+%% compliance with the License. You should have received a copy of the
+%% Erlang Public License along with this software. If not, it can be
+%% retrieved online at http://www.erlang.org/.
+%%
+%% Software distributed under the License is distributed on an "AS IS"
+%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
+%% the License for the specific language governing rights and limitations
+%% under the License.
+%%
+%% %CopyrightEnd%
+%%
+
+%%
+%%----------------------------------------------------------------------
+%% Purpose: Supervisor for a SSL/TLS connection
+%%----------------------------------------------------------------------
+-module(tls_connection_sup).
+
+-behaviour(supervisor).
+
+%% API
+-export([start_link/0, start_link_dist/0]).
+-export([start_child/1, start_child_dist/1]).
+
+%% Supervisor callback
+-export([init/1]).
+
+%%%=========================================================================
+%%% API
+%%%=========================================================================
+start_link() ->
+ supervisor:start_link({local, ?MODULE}, ?MODULE, []).
+
+start_link_dist() ->
+ supervisor:start_link({local, ssl_connection_sup_dist}, ?MODULE, []).
+
+start_child(Args) ->
+ supervisor:start_child(?MODULE, Args).
+
+start_child_dist(Args) ->
+ supervisor:start_child(ssl_connection_sup_dist, Args).
+
+%%%=========================================================================
+%%% Supervisor callback
+%%%=========================================================================
+init(_O) ->
+ RestartStrategy = simple_one_for_one,
+ MaxR = 0,
+ MaxT = 3600,
+
+ Name = undefined, % As simple_one_for_one is used.
+ StartFunc = {tls_connection, start_link, []},
+ Restart = temporary, % E.g. should not be restarted
+ Shutdown = 4000,
+ Modules = [tls_connection],
+ Type = worker,
+
+ ChildSpec = {Name, StartFunc, Restart, Shutdown, Type, Modules},
+ {ok, {{RestartStrategy, MaxR, MaxT}, [ChildSpec]}}.