-
Notifications
You must be signed in to change notification settings - Fork 12
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
SOCKS5 Flutter #26
Comments
Hi @xAffan. We use this plugin in https://github.com/Foundation-Devices/envoy and a Rust dependency of ours (https://github.com/bitcoindevkit) looks up onion addresses without fail. We have never actually tried accessing .onions from Dart code. Maybe @sneurlax did? |
I haven't found a way to lookup onion addresses from dart. Both of you seem much more experienced than me, therefore, I would be very happy if you guided me how to lookup onion addresses preferably from dart, if not, then from bitcoindevkit dependency(?) More specifically, I need a way to use tor proxy with onion lookups on normal http libraries in dart. |
I do get onion responses when running arti locally on desktop, but haven't thoroughly tested it when arti's running as bundled in this package. We are still waiting on arti to release full, secure/private onion addresses and will probably finish integration after that. As of 1.1.11 I thought arti had experimental .onion address support. @xAffan I had to write a custom SOCKS5 package for communication with electrumx because nothing else I found worked/supported sockets properly. You might have success finding something else that works, but this may work or we may just have to patch it for SOCKS5H: https://github.com/cypherstack/socks_socket |
It does actually support .onion. However, I am unable to connect to it properly using flutter, I just need to be able to use socks5h with some http client. I succeeded with using socks5 because someone had made a package implementating socks5 but I suspect it is not socks5h and does DNS locally. |
May I ask what you're trying to connect to? And/or what SOCKS5 package you're using? I've tried these SOCKS5 dart packages which work for basic functionality but didn't totally work for what we needed (with ElectrumX use with sockets)--unrelated to your .onion address issues, so I'd check them out in case they might work: This is what I wrote when none of the above worked perfectly for what we needed, so maybe this will help? If none of the above work, if you can provide a working commandline example of a SOCKS5H command/response or an example of a SOCKS5 call that works and a SOCKS5H one that doesn't, that would help me get started on extending that socks_socket package to support SOCKS5H. |
PS if none of the upper packages work, the links from here might help with using socks_socket. I need to finish it, add an example, and document it a bit better :D but hopefully one of the 3 other packages above work for your use case. |
I was using https://github.com/LacticWhale/socks_dart |
Tor Project: FAQ basically says we should use SOCKS 4a. If we use SOCKS 5, it won't work. It is apparently on purpose to avoid DNS lookups. I tried it a few years ago in C code, doing SOCKS 4a handshake myself. It works. I also use Boost.Asio and libcurl respectively in my C++ codes. They all work as long as we stick to SOCKS 4a. I'm new to Flutter, and haven't tried using SOCKS 4a in Dart code to connect onion service yet. If using SOCKS 4a works in Dart/Flutter code, please let us know. Thanks. |
It is possible to use SOCKS 4a. |
Hey @xAffan, did you ever try socks_socket.dart? I had to use it again today for connecting electrum_adapter via Tor. If you can report some issues/errors, I'll try and fix them. Or if you provide some minimal reproducible code showing what you want to succeed that doesn't, I'll try and extend socks_socket to accomplish that. You can use it like
|
I would use this but I am not quite sure how to use HTTP protocol with this? I need to make some GET and POST requests, and I am not exactly sure how to. |
@xAffan if you don't need it for electrum servers, maybe my socks_socket is not for you. But see https://github.com/Foundation-Devices/tor/blob/main/lib/socks_socket.dart#L321 (the
These may not work if you copy and paste them but show the general approach you might take towards making GET and POST requests via socks_socket. It may help if you can post a small example of exactly what you're trying to do (or something similar enough) |
Unfortunately, raw requests won't do - they will take too much time and I regularly need to interact with a site. Launching lib\main.dart on Windows in debug mode... [ERROR:flutter/runtime/dart_vm_initializer.cc(41)] Unhandled Exception: SocketException: Failed host lookup: 'duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion' (OS Error: No such host is known. , errno = 11001) |
@sneurlax It'd be great if we can connect with onion servers, e.g. DuckDuckGo For now, we can only connect to ordinary websites. If we try to connect to an onion server, it will fail. In my case of using LacticWhale/socks_dart to connect an onion router, it throws:
By the way, does your sneurlax/socks_socket also provide a wayt to create or adapt a |
I suspect, it's not using Tor Proxy for DNS resolution, which is why host lookup fails. It seems as though there is no solution that I am aware of |
In my case, it's LacticWhale/socks_dart that tries to do DNS lookup and fails, which behavior is well-described in Tor Project: FAQ
Re-edit: Remove misleading information. |
That is certainly some good insight. I saw a package claiming to support socks4/5. Although, when I tried it, it simply did not work. Worth a try? https://github.com/tayoji-io/socks_proxy |
I've tried tayoji-io/socks_proxy: dart package,http/socks4/socks5 proxy too. Same. It doesn't work. My best guess is that both tayoji-io/socks_proxy and LacticWhale/socks_dart themselves tried to do DNS lookup and failed, before they had a chance to send the .onion domain name to the Tor proxy. After a little research and chatting with Copilot, I think I was wrong about SOCKS 4a. SOCKS 4a accepts both IPv4 address and domain name, just like SOCKS 5 does. The reason why we cannot access onion servers through Tor proxy has nothing to do with using SOCKS 5 or SOCKS 4a, but rather the SOCKS client packages we used all try to DNS lookup the .onion domain name, which of cause will fail because no DNS servers know anything about the top-level domain .onion. |
@xAffan I am now connecting to .onion nodes using* (basically) this plugin, but you have to edit
*: cypherstack/tor, which is basically this repo, but has small differences. It will work if you fork this repo and edit that line in Cargo.toml |
I'm not sure how to use plugins in flutter outside of pub add. Maybe, enable onion support but give a warning? |
if it's still an issue I'll try to submit a PR to fix it for you @xAffan. How's it working these days if you just pub add tor a fresh plugin? or fork this and edit the example. maybe we need to package in some dependency that's missing |
Onion lookups should work with #52 |
How do you actually use the socks5 proxy in flutter? It seems possible but the DNS lookup is still performed locally, causing onion lookup to fail!
We have to use socks5h/socks4a not socks5/socks4.
The text was updated successfully, but these errors were encountered: