diff options
| author | 2022-09-17 21:44:39 -0700 | |
|---|---|---|
| committer | 2022-09-17 21:45:03 -0700 | |
| commit | 745cc5c65502f1c1bcd69392e526d63f04653e11 (patch) | |
| tree | 931f1da8c320229a21e01a3d21310a4ca5e3a8b7 | |
| parent | 3719c3b736fde4fb3fd164c32f1494c5125bee6f (diff) | |
| download | bun-745cc5c65502f1c1bcd69392e526d63f04653e11.tar.gz bun-745cc5c65502f1c1bcd69392e526d63f04653e11.tar.zst bun-745cc5c65502f1c1bcd69392e526d63f04653e11.zip | |
Handle missing 0\r\n chunk in HTTP client
| -rw-r--r-- | src/http_client_async.zig | 18 | 
1 files changed, 17 insertions, 1 deletions
| diff --git a/src/http_client_async.zig b/src/http_client_async.zig index c73db732e..cb59ef173 100644 --- a/src/http_client_async.zig +++ b/src/http_client_async.zig @@ -485,13 +485,29 @@ pub fn onClose(      _ = socket;      log("Closed  {s}\n", .{client.url.href}); +    const in_progress = client.state.stage != .done and client.state.stage != .fail; + +    // if the peer closed after a full chunk, treat this +    // as if the transfer had complete, browsers appear to ignore +    // a missing 0\r\n chunk +    if (in_progress and client.state.transfer_encoding == .chunked) { +        if (picohttp.phr_decode_chunked_is_in_data(&client.state.chunked_decoder) == 0) { +            if (client.state.compressed_body orelse client.state.body_out_str) |body| { +                if (body.list.items.len > 0) { +                    client.done(comptime is_ssl, if (is_ssl) &http_thread.https_context else &http_thread.http_context, socket); +                    return; +                } +            } +        } +    } +      if (client.allow_retry) {          client.allow_retry = false;          client.start(client.state.request_body, client.state.body_out_str.?);          return;      } -    if (client.state.stage != .done and client.state.stage != .fail) +    if (in_progress)          client.fail(error.ConnectionClosed);  }  pub fn onTimeout( | 
