From b1e6406e4f0871c656f92fdd0755c8ef82be2818 Mon Sep 17 00:00:00 2001 From: juhlig Date: Tue, 14 May 2019 11:27:04 +0200 Subject: Add support for UNIX domain sockets It was working already but the types were wrong and some small details needed to be corrected. --- src/ranch.erl | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'src/ranch.erl') diff --git a/src/ranch.erl b/src/ranch.erl index a0fdea6..86a1c30 100644 --- a/src/ranch.erl +++ b/src/ranch.erl @@ -201,14 +201,19 @@ get_status(Ref) -> running end. --spec get_addr(ref()) -> {inet:ip_address(), inet:port_number()} | {undefined, undefined}. +-spec get_addr(ref()) -> {inet:ip_address(), inet:port_number()} | + {local, binary()} | {undefined, undefined}. get_addr(Ref) -> ranch_server:get_addr(Ref). -spec get_port(ref()) -> inet:port_number() | undefined. get_port(Ref) -> - {_, Port} = get_addr(Ref), - Port. + case get_addr(Ref) of + {local, _} -> + undefined; + {_, Port} -> + Port + end. -spec get_connections(ref(), active|all) -> non_neg_integer(). get_connections(Ref, active) -> @@ -263,7 +268,12 @@ info(Ref) -> listener_info(Ref, Pid) -> [_, Transport, _, Protocol, _] = ranch_server:get_listener_start_args(Ref), Status = get_status(Ref), - {IP, Port} = get_addr(Ref), + {IP, Port} = case get_addr(Ref) of + Addr = {local, _} -> + {Addr, undefined}; + Addr -> + Addr + end, MaxConns = get_max_connections(Ref), TransOpts = ranch_server:get_transport_options(Ref), ProtoOpts = get_protocol_options(Ref), -- cgit v1.2.3