diff options
| author | 2021-12-23 00:43:34 -0800 | |
|---|---|---|
| committer | 2021-12-23 00:43:34 -0800 | |
| commit | e1505d88b108ce42e0cca2ba1faa2f3745ab7291 (patch) | |
| tree | 3f771f3c3353d760cd17d5d9954ce8f7c444183c /src/http_client_async.zig | |
| parent | d04e5ea0baf3b63a7bc99b472813719b3d365be4 (diff) | |
| download | bun-e1505d88b108ce42e0cca2ba1faa2f3745ab7291.tar.gz bun-e1505d88b108ce42e0cca2ba1faa2f3745ab7291.tar.zst bun-e1505d88b108ce42e0cca2ba1faa2f3745ab7291.zip | |
Prevent crash due to SIGPIPE
Diffstat (limited to 'src/http_client_async.zig')
| -rw-r--r-- | src/http_client_async.zig | 24 | 
1 files changed, 21 insertions, 3 deletions
| diff --git a/src/http_client_async.zig b/src/http_client_async.zig index 8b8bd6082..192aebfbf 100644 --- a/src/http_client_async.zig +++ b/src/http_client_async.zig @@ -7,15 +7,18 @@ const Method = @import("./http/method.zig").Method;  const Api = @import("./api/schema.zig").Api;  const Lock = @import("./lock.zig").Lock;  const HTTPClient = @This(); -const SOCKET_FLAGS = os.SOCK_CLOEXEC;  const Zlib = @import("./zlib.zig");  const StringBuilder = @import("./string_builder.zig");  const AsyncIO = @import("io");  const ThreadPool = @import("thread_pool");  const boring = @import("boringssl"); -  const NetworkThread = @import("network_thread"); +const SOCKET_FLAGS: u32 = if (Environment.isLinux) +    os.SOCK_CLOEXEC | os.MSG_NOSIGNAL +else +    os.SOCK_CLOEXEC; +  const extremely_verbose = false;  fn writeRequest( @@ -656,6 +659,8 @@ const AsyncSocket = struct {              try_cached_index: {                  if (address_list.index) |i| {                      const address = list.addrs[i]; +                    if (address_list.invalidated) continue :outer; +                      this.connectToAddress(address) catch |err| {                          if (err == error.ConnectionRefused) {                              address_list.index = null; @@ -669,6 +674,7 @@ const AsyncSocket = struct {              }              for (list.addrs) |address, i| { +                if (address_list.invalidated) continue :outer;                  this.connectToAddress(address) catch |err| {                      if (err == error.ConnectionRefused) continue;                      address_list.invalidate(); @@ -678,6 +684,8 @@ const AsyncSocket = struct {                  return;              } +            if (address_list.invalidated) continue :outer; +              address_list.invalidate();              return error.ConnectionRefused;          } @@ -1443,9 +1451,19 @@ pub fn connect(      try connector.connect(this.url.hostname, port);      var client = std.x.net.tcp.Client{ .socket = std.x.os.Socket.from(this.socket.socket.socket) }; -    client.setNoDelay(true) catch {};      client.setReadBufferSize(BufferPool.len) catch {};      client.setQuickACK(true) catch {}; + +    if (comptime Environment.isMac) { +        // Don't crash if the server disconnects. +        std.os.setsockopt( +            client.socket.fd, +            std.os.IPPROTO_TCP, +            std.os.SO_NOSIGPIPE, +            std.mem.asBytes(&@as(u32, @boolToInt(true))), +        ) catch {}; +    } +      this.tcp_client = client;      if (this.timeout > 0) {          client.setReadTimeout(@truncate(u32, this.timeout / std.time.ns_per_ms)) catch {}; | 
