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

WebSocketPeer uses TLSv1.2 and can't change to TLSv1.3 #92101

Closed
DjSapsan opened this issue May 19, 2024 · 12 comments · Fixed by #96394
Closed

WebSocketPeer uses TLSv1.2 and can't change to TLSv1.3 #92101

DjSapsan opened this issue May 19, 2024 · 12 comments · Fixed by #96394

Comments

@DjSapsan
Copy link

DjSapsan commented May 19, 2024

Tested versions

v4.2.1.stable.official [15073af]
...
Godot_v4.3-dev6_linux

System information

Godot v4.2.2.stable - Ubuntu 23.10 23.10 - X11 - GLES3 (Compatibility) - llvmpipe (LLVM 15.0.7, 256 bits) () - AMD Ryzen 9 5900X 12-Core Processor (24 Threads)

Issue description

image

I'm connecting to a WSS source from Godot. Wireshark shows that it uses TLSv1.2 protocol.
The connection is STATE_OPEN, but packets are not sent from server to me.

When I'm testing the same WSS address in Postman everything works perfectly and Wireshark shows that TLSv1.3 is used. Also there are some other differences.

Also, the documentation is absolutely useless. It doesn't explain about limitations and is very limited.

I asked about the problem 4 times in discord and literally 0 answers.

Steps to reproduce

connect to any websocket that is uses TLSv1.3

Minimal reproduction project (MRP)

Archive.zip

For some unclear reason this MRP can't even connect with 100% the same code as original.
The original can at least connect, although doesn't receive anything

@akien-mga
Copy link
Member

Also, the documentation is absolute shit (i'm sorry, I just frustrated).

Please don't do that, this is a breach of our Code of Conduct.

We can understand frustration, but we shouldn't have to put up with it in our bug tracker. This doesn't make contributors want to help solve your issue.

Now, if you could provide links to the documentation you're talking about and details in what you think is lacking, that would be constructive and actionable.

@DjSapsan
Copy link
Author

Now, if you could provide links to the documentation you're talking about and details in what you think is lacking, that would be constructive and actionable.

This whole article is useless - https://docs.godotengine.org/cs/4.x/classes/class_websocketpeer.html
Also this part in it:
image

@akien-mga
Copy link
Member

Please define "useless", that's not in any way constructive or actionable criticism.

I see a lot of useful information there myself. Some descriptions might be lacking, and to know in what way they are lacking, we would benefit from you explaining what you were expecting to find and couldn't.

@DjSapsan
Copy link
Author

I'm expecting to find how to change TLS version at least

@DjSapsan
Copy link
Author

Ok, I heard that TLSv1.3 is due to be added soon. If it's true, then the issue can be closed.
I will just update my version

@Calinou
Copy link
Member

Calinou commented May 21, 2024

Ok, I heard that TLSv1.3 is due to be added soon. If it's true, then the issue can be closed. I will just update my version

Where did you hear this? I don't know if Godot uses a recent enough mbedTLS version to support TLS 1.3 (it probably does already).

@DjSapsan
Copy link
Author

image
Maybe it's wrong. So idk what to do with TLSv1.3

@DjSapsan DjSapsan reopened this May 22, 2024
@bruvzg
Copy link
Member

bruvzg commented May 22, 2024

TLSv1.3 is supported by the used version of mbedTLS, but it is disabled:

// mbedTLS 3.6 finally enabled TLSv1.3 by default, but it requires some mobule
// changes, and to enable PSA crypto (new "standard" API specification).
// Disable it for now.
#undef MBEDTLS_SSL_PROTO_TLS1_3

@akien-mga
Copy link
Member

So some actionables:

  • Clarify docs on the used TLS version, and that 1.3 isn't supported yet.
  • Clarify docs on how to use the supported_protocols property (what's the syntax, what are valid values)
  • Network team to open a new issue about enabling TLSv1.3 support in mbedTLS for 4.4.

@godotengine/network

@Faless
Copy link
Collaborator

Faless commented May 23, 2024

Clarify docs on how to use the supported_protocols property (what's the syntax, what are valid values)

The documentation states supported_protocols specifies the WebSocket sub-protocol(s) to advertise during handshake.

This is part of the WebSocket standard (should we add this link in the docs?) and has nothing to do with the TLS version (which is not part of WebSocket itself).

The TLS version supported is explained in the HTTPClient, we should link to it from the websocket docs (like we do in the HTTPRequest class), and probably update it because AFAIR support for TLSv1.0/1.1 has been dropped (they have long been deprecated as insecure), so only TLSv1.2 is supported right now (98% of the web).

@DjSapsan
Copy link
Author

@Faless , TLS 1.3 is supported by 62% websites.

Hi here again. Is there any updates regarding this support?
I can't do anything further without it. IDK, I'm gonna redo my project with a different engine or just abandon it...

@Faless
Copy link
Collaborator

Faless commented Sep 25, 2024

@DjSapsan there's a PR enabling it: #96394 , but there's an error when building with MSVC which I don't how how to solve (related to Windows inability to handle long command lines)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants