Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Websocket upgrade fails on unix socket #318

Open
mortont opened this issue Sep 22, 2023 · 4 comments
Open

Websocket upgrade fails on unix socket #318

mortont opened this issue Sep 22, 2023 · 4 comments
Milestone

Comments

@mortont
Copy link

mortont commented Sep 22, 2023

When upgrading a unix socket connection to a websocket connection using this snippet I get a failure ws_upgrade_failed response. I'm able to connect to this service and perform a websocket upgrade using other clients in other languages, so I don't think it is an issue with the server implementation

    {:ok, pid} = :gun.open_unix('test.sock', %{})

    case :gun.await_up(pid) do
      {:ok, _} ->
        :ok

      {:error, error} ->
        IO.inspect(error)
    end

    streamref = :gun.ws_upgrade(pid, '/ws')

    receive do
      {:gun_upgrade, connpid, streamref, [<<"websocket">>], headers} ->
        :ok

      {:gun_response, connpid, _, _, status, headers} ->
        exit({:ws_upgrade_failed, status, headers})

      {:gun_error, connpid, streamref, reason} ->
        exit({:ws_upgrade_failed, reason})
    after
      1000 ->
        Logger.error("timeout connecting")
    end

results

{:ws_upgrade_failed, 400, [{"connection", "close"}, {"content-length", "0"}]}

This is successful if I use a standard :gun.open connection over TCP/IP, is there something I'm missing for the unix socket case?

@essen
Copy link
Member

essen commented Sep 23, 2023

Please add trace => true to the map given to open_unix so we can see what's going on.

@mortont
Copy link
Author

mortont commented Sep 25, 2023

I've attached the trace, I don't see anything obvious at first glance: trace.txt

@essen
Copy link
Member

essen commented Sep 25, 2023

Right the problem is with the host header, since you are using a Unix socket you will need to provide the host header for every request you make as Gun is not able to figure it out and sends garbage.

Gun should not send garbage so this ticket should remain open, and I believe users of unix sockets will be required to provide the host themselves as we cannot guess it in this scenario so the documentation should be updated to reflect that.

Thanks for the trace!

@mortont
Copy link
Author

mortont commented Sep 25, 2023

Thanks! That fixed it for me. For anyone coming here with the same issue, this was my change:

streamref = :gun.ws_upgrade(pid, '/ws', [{<<"host">>, <<"localhost">>}])

@essen essen added this to the 2.2.0 milestone Jan 15, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants