From 166761483d9c511766fbfe6d4e501c3826f949d9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Hoguin?= Date: Tue, 22 Jan 2013 17:08:32 +0100 Subject: Do not crash if connection is closed while sending static file --- src/cowboy_static.erl | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'src/cowboy_static.erl') diff --git a/src/cowboy_static.erl b/src/cowboy_static.erl index 2c41c91..373ea52 100644 --- a/src/cowboy_static.erl +++ b/src/cowboy_static.erl @@ -322,8 +322,12 @@ content_types_provided(Req, #state{filepath=Filepath, file_contents(Req, #state{filepath=Filepath, fileinfo={ok, #file_info{size=Filesize}}}=State) -> Writefile = fun(Socket, Transport) -> - {ok, _} = Transport:sendfile(Socket, Filepath), - ok + %% Transport:sendfile/2 may return {error, closed} + %% if the connection is closed while sending the file. + case Transport:sendfile(Socket, Filepath) of + {ok, _} -> ok; + {error, closed} -> ok + end end, {{stream, Filesize, Writefile}, Req, State}. -- cgit v1.2.3