While looking into NAT punching I noticed the following weird behavior:
If you start the game and go directly to the public server list, click on servers and try to connect one no NatPunchRequest messages are sent by the client.
If you start the game and choose "Host new game" that is publicly visible, let it run for a few seconds before exiting, and after that go browse the public server list then the client sends NatPunchRequest messages for each server you click on and before each connection attempt to a server.
I don't think this is how it's supposed to work.
[Rseding91] [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
-
- Fast Inserter
- Posts: 214
- Joined: Fri Oct 05, 2018 4:34 pm
- Contact:
Re: [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
That is intended. Nat punching is only relevant for the host and it's design is to keep the port open on the host side so client packets reach the host. The act of sending packets from the client to the server is itself nat-punching on the client side.Hornwitser wrote: ↑Tue Apr 06, 2021 9:58 pm If you start the game and go directly to the public server list, click on servers and try to connect one no NatPunchRequest messages are sent by the client.
That doesn't sound intended. The nat-punch sending should stop as soon as the server has been quit.Hornwitser wrote: ↑Tue Apr 06, 2021 9:58 pm If you start the game and choose "Host new game" that is publicly visible, let it run for a few seconds before exiting, and after that go browse the public server list then the client sends NatPunchRequest messages for each server you click on and before each connection attempt to a server.
I don't think this is how it's supposed to work.
If you want to get ahold of me I'm almost always on Discord.
-
- Fast Inserter
- Posts: 214
- Joined: Fri Oct 05, 2018 4:34 pm
- Contact:
Re: [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
In 1.1.30 NatPunchRequest is not sent unless you first host a game. If NatPunchRequest packets are not sent then nat punching will not work. Nat punching is therefore highly relevant to the client, if the client doesn't send a NatPunchRequest to your ping pong server that is then forwarded to the target server then no nat punching can take place.
Re: [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
I think you're misunderstanding part of what nat punching is/does. The ping-pong servers don't relay anything; they simply reply to the packet sent to them with the IP they got the packet on.
So in that regard: the ping-pong server only talks with the computer that sent it the packets. It never sends anything to other computers.
So in that regard: the ping-pong server only talks with the computer that sent it the packets. It never sends anything to other computers.
If you want to get ahold of me I'm almost always on Discord.
-
- Fast Inserter
- Posts: 214
- Joined: Fri Oct 05, 2018 4:34 pm
- Contact:
Re: [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
And I think you don't understand how nat punching works. But the good news is that it actually functions in 0.16.51, so I've put together this demonstration video for you that shows the ping pong servers does relay nat punch requests contrary to what you're saying, and that this relaying is integral to making nat punching work.
https://youtu.be/08u9eD7Iieo
https://youtu.be/08u9eD7Iieo
Re: [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
After talking with one of my co-workers I believe it's time for me to eat-crow as the saying goes and admit I was wrong. I'll be looking into this more and seeing if I can figure out what's going on.
If you want to get ahold of me I'm almost always on Discord.
Re: [Rseding91] [1.1.30] NatPunchRequest not sent unless a multiplayer game has been hosted first
Ok, it's now fixed for the next release.
If you want to get ahold of me I'm almost always on Discord.