Skip to content
New issue

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

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

Already on GitHub? # to your account

use outgoing interface's IP for UDP relay port #1029

Closed
wants to merge 1 commit into from

Conversation

ge9
Copy link
Contributor

@ge9 ge9 commented Jun 11, 2024

Currently relay ports for SOCKS UDP associate are obtained with nil ([::]:0), and then replied to clients with the IP replaced by TCP local address.
My implementation uses the TCP local address instead of nil when getting UDP relay ports.
This solves possible problems in situations where the SOCKS server can be seen through more than one IP addresses.
For example, if we use some external interface address (like 10.0.0.1) to access gost SOCKS5 proxy running on the same machine as client, only my implementation will work, because current implementation will send back UDP packets using localhost (127.0.0.1), which is different from the replied relay port.
Also, the current implementation typically replies IPv4-mapped IPv6 address to IPv4 clients (like ::ffff:10.0.0.1), which is incompatible with redsocks (https://github.com/semigodking/redsocks) which is one of the most widely-used transparent SOCKS5 proxy clients. My implementation will also fix this.

@ge9 ge9 closed this Jun 13, 2024
@ge9
Copy link
Contributor Author

ge9 commented Jun 13, 2024

Sorry the gost binary is mistakenly included. I'll resend another pull request.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant