diff options
author | Loïc Hoguin <[email protected]> | 2012-04-12 23:22:52 +0200 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2012-04-14 17:52:47 +0200 |
commit | 4156fa3ebb978a21b52abf94202bb3d7676f4c03 (patch) | |
tree | e05c4cac592afeace0f1722bd2111d0d88eb94d0 /src/ranch_listener_sup.erl | |
parent | f971ec1ced3758834d6e98ab3c7fafddd8bf9da6 (diff) | |
download | ranch-4156fa3ebb978a21b52abf94202bb3d7676f4c03.tar.gz ranch-4156fa3ebb978a21b52abf94202bb3d7676f4c03.tar.bz2 ranch-4156fa3ebb978a21b52abf94202bb3d7676f4c03.zip |
Import the acceptor code from Cowboy
Modules were renamed. The 'cowboy_' prefix became 'ranch_'.
At the same time, ranch_ssl_transport became ranch_ssl,
and ranch_tcp_transport became ranch_tcp, because appending
'_transport' felt a bit redundant considering SSL and TCP
clearly are transports.
One test has been added to make sure everything is working.
Diffstat (limited to 'src/ranch_listener_sup.erl')
-rw-r--r-- | src/ranch_listener_sup.erl | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/src/ranch_listener_sup.erl b/src/ranch_listener_sup.erl new file mode 100644 index 0000000..c33194f --- /dev/null +++ b/src/ranch_listener_sup.erl @@ -0,0 +1,46 @@ +%% Copyright (c) 2011-2012, Loïc Hoguin <[email protected]> +%% +%% Permission to use, copy, modify, and/or distribute this software for any +%% purpose with or without fee is hereby granted, provided that the above +%% copyright notice and this permission notice appear in all copies. +%% +%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +%% @private +-module(ranch_listener_sup). +-behaviour(supervisor). + +-export([start_link/5]). %% API. +-export([init/1]). %% supervisor. + +%% API. + +-spec start_link(non_neg_integer(), module(), any(), module(), any()) + -> {ok, pid()}. +start_link(NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts) -> + MaxConns = proplists:get_value(max_connections, TransOpts, 1024), + {ok, SupPid} = supervisor:start_link(?MODULE, []), + {ok, ListenerPid} = supervisor:start_child(SupPid, + {ranch_listener, {ranch_listener, start_link, [MaxConns, ProtoOpts]}, + permanent, 5000, worker, [ranch_listener]}), + {ok, ConnsPid} = supervisor:start_child(SupPid, + {ranch_conns_sup, {ranch_conns_sup, start_link, []}, + permanent, 5000, supervisor, [ranch_conns_sup]}), + {ok, _PoolPid} = supervisor:start_child(SupPid, + {ranch_acceptors_sup, {ranch_acceptors_sup, start_link, [ + NbAcceptors, Transport, TransOpts, + Protocol, ProtoOpts, ListenerPid, ConnsPid + ]}, permanent, 5000, supervisor, [ranch_acceptors_sup]}), + {ok, SupPid}. + +%% supervisor. + +-spec init([]) -> {ok, {{one_for_all, 10, 10}, []}}. +init([]) -> + {ok, {{one_for_all, 10, 10}, []}}. |