From 855e9652fa40673d8f1ff40fd262963941e28fef Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= Date: Wed, 30 Jan 2013 23:38:51 +0100 Subject: Make sure the peer name is always available --- src/cowboy_req.erl | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/cowboy_req.erl b/src/cowboy_req.erl index 5cb7aa3..0745192 100644 --- a/src/cowboy_req.erl +++ b/src/cowboy_req.erl @@ -187,7 +187,8 @@ new(Socket, Transport, Method, Path, Query, Fragment, Version, Headers, Host, Port, Buffer, CanKeepalive, Compress, OnResponse) -> - Req = #http_req{socket=Socket, transport=Transport, pid=self(), + {ok, Peer} = Transport:peername(Socket), + Req = #http_req{socket=Socket, transport=Transport, pid=self(), peer=Peer, method=Method, path=Path, qs=Query, fragment=Fragment, version=Version, headers=Headers, host=Host, port=Port, buffer=Buffer, resp_compress=Compress, onresponse=OnResponse}, @@ -219,9 +220,6 @@ version(Req) -> %% @doc Return the peer address and port number of the remote host. -spec peer(Req) -> {{inet:ip_address(), inet:port_number()}, Req} when Req::req(). -peer(Req=#http_req{socket=Socket, transport=Transport, peer=undefined}) -> - {ok, Peer} = Transport:peername(Socket), - {Peer, Req#http_req{peer=Peer}}; peer(Req) -> {Req#http_req.peer, Req}. -- cgit v1.2.3