aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2011-05-24 20:52:19 +0200
committerLoïc Hoguin <[email protected]>2011-05-24 20:52:19 +0200
commit0720d6b9e3c8655b6222a84a2f37fcab04b3dd94 (patch)
tree389cadd8c5b739c144a74fb27ba2ec6b281e7d20 /src
parent4c4030a792a94d96f8bda5076fcfdc03a590030e (diff)
downloadcowboy-0720d6b9e3c8655b6222a84a2f37fcab04b3dd94.tar.gz
cowboy-0720d6b9e3c8655b6222a84a2f37fcab04b3dd94.tar.bz2
cowboy-0720d6b9e3c8655b6222a84a2f37fcab04b3dd94.zip
Automatically start crypto, public_key and ssl if needed.
Following mochiweb and misultin's example here even though I'm not too thrilled about starting them and not stopping but it's optional and the application's author can start/stop them as normal anyway.
Diffstat (limited to 'src')
-rw-r--r--src/cowboy_ssl_transport.erl11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/cowboy_ssl_transport.erl b/src/cowboy_ssl_transport.erl
index cbe1ac1..bafa99b 100644
--- a/src/cowboy_ssl_transport.erl
+++ b/src/cowboy_ssl_transport.erl
@@ -30,6 +30,7 @@ messages() -> {ssl, ssl_closed, ssl_error}.
| {keyfile, KeyPath::string()} | {password, Password::string()}])
-> {ok, LSocket::ssl:sslsocket()} | {error, Reason::atom()}.
listen(Opts) ->
+ require([crypto, public_key, ssl]),
{port, Port} = lists:keyfind(port, 1, Opts),
Backlog = proplists:get_value(backlog, Opts, 1024),
{certfile, CertFile} = lists:keyfind(certfile, 1, Opts),
@@ -80,6 +81,16 @@ close(Socket) ->
%% Internal.
+-spec require(Apps::list(module())) -> ok.
+require([]) ->
+ ok;
+require([App|Tail]) ->
+ case application:start(App) of
+ ok -> ok;
+ {error, {already_started, App}} -> ok
+ end,
+ require(Tail).
+
-spec ssl_accept(CSocket::ssl:sslsocket(), Timeout::timeout())
-> {ok, Socket::ssl:sslsocket()} | {error, Reason::closed | timeout | atom()}.
ssl_accept(CSocket, Timeout) ->