Commit af5ed080 authored by Dietmar Maurer's avatar Dietmar Maurer

fix bug 401: disable connection timeout during API call processing

Only enable timeouts when we really expect data to be send/received.
parent a5189b60
...@@ -85,13 +85,24 @@ sub log_aborted_request { ...@@ -85,13 +85,24 @@ sub log_aborted_request {
$self->log_request($reqstate); $self->log_request($reqstate);
} }
sub client_do_disconnect { sub cleanup_reqstate {
my ($self, $reqstate) = @_; my ($reqstate) = @_;
delete $reqstate->{log};
delete $reqstate->{request};
delete $reqstate->{proto};
delete $reqstate->{accept_gzip};
if ($reqstate->{tmpfilename}) { if ($reqstate->{tmpfilename}) {
unlink $reqstate->{tmpfilename}; unlink $reqstate->{tmpfilename};
delete $reqstate->{tmpfilename}; delete $reqstate->{tmpfilename};
} }
}
sub client_do_disconnect {
my ($self, $reqstate) = @_;
cleanup_reqstate($reqstate);
my $hdl = delete $reqstate->{hdl}; my $hdl = delete $reqstate->{hdl};
...@@ -117,15 +128,7 @@ sub finish_response { ...@@ -117,15 +128,7 @@ sub finish_response {
my $hdl = $reqstate->{hdl}; my $hdl = $reqstate->{hdl};
delete $reqstate->{log}; cleanup_reqstate($reqstate);
delete $reqstate->{request};
delete $reqstate->{proto};
delete $reqstate->{accept_gzip};
if ($reqstate->{tmpfilename}) {
unlink $reqstate->{tmpfilename};
delete $reqstate->{tmpfilename};
}
if (!$self->{end_loop} && $reqstate->{keep_alive} > 0) { if (!$self->{end_loop} && $reqstate->{keep_alive} > 0) {
# print "KEEPALIVE $reqstate->{keep_alive}\n" if $self->{debug}; # print "KEEPALIVE $reqstate->{keep_alive}\n" if $self->{debug};
...@@ -148,6 +151,10 @@ sub response { ...@@ -148,6 +151,10 @@ sub response {
#print "$$: send response: " . Dumper($resp); #print "$$: send response: " . Dumper($resp);
# activate timeout
$reqstate->{hdl}->timeout_reset();
$reqstate->{hdl}->timeout($self->{timeout});
$nocomp = 1 if !$reqstate->{accept_gzip}; $nocomp = 1 if !$reqstate->{accept_gzip};
my $code = $resp->code; my $code = $resp->code;
...@@ -432,6 +439,8 @@ sub handle_api2_request { ...@@ -432,6 +439,8 @@ sub handle_api2_request {
my $res = PVE::REST::rest_handler($rpcenv, $clientip, $method, $rel_uri, $auth, $params); my $res = PVE::REST::rest_handler($rpcenv, $clientip, $method, $rel_uri, $auth, $params);
AnyEvent->now_update(); # in case somebody called sleep()
$rpcenv->set_user(undef); # clear after request $rpcenv->set_user(undef); # clear after request
if ($res->{proxy}) { if ($res->{proxy}) {
...@@ -470,6 +479,10 @@ sub handle_request { ...@@ -470,6 +479,10 @@ sub handle_request {
my $method = $r->method(); my $method = $r->method();
my $path = $r->uri->path(); my $path = $r->uri->path();
# disable timeout on handle (we already have all data we need)
# we re-enable timeout in response()
$reqstate->{hdl}->timeout(0);
if ($path =~ m!$baseuri!) { if ($path =~ m!$baseuri!) {
$self->handle_api2_request($reqstate, $auth); $self->handle_api2_request($reqstate, $auth);
return; return;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment