-
Notifications
You must be signed in to change notification settings - Fork 225
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
Http Proxy Support (+ relevant tokio-tungstenite discussion) #258
Comments
Maybe. If you want to connect using If you expect to the proxy to hangle HTTP upgrades properly and send something like Note that this library is not well-maintained, and you should try |
An example of going through HTTP proxy to a secure websocket (with tokio and tungstenite, obviously, as prescribed by the previous commenter): let tcp = TcpStream::connect("proxy_domain:80").await?;
let (mut request_sender, conn) = conn::handshake(tcp).await?;
let conn = tokio::spawn(conn.without_shutdown());
// create an HTTP method CONNECT request, port mandatory, even if 80 or 443
let req = Request::connect("domain.tld:443")
.header("Proxy-Authorization", format!("Basic {}", proxy_base64))
.body(())?;
let res = request_sender.send_request(req).await?;
assert!(response.status() == StatusCode::OK);
// `into_parts` panics if the connection is HTTP/2! Which might be negotiated if the proxy_domain is https! So maybe specify to use HTTP 1.1 above! (we don't worry this time, we are connecting to HTTP, on port 80. Does `without_shutdown` solve that instead? can we do a HTTP/2 connection to the proxy? find out next time on dragonballz
// unwrapping the joinhandle against panic, then the withoutshutdown
let tcp = connection.await??.io;
let req = Request::get("wss://domain.tld/path?query")
.header("Sec-WebSocket-Key", tungstenite::handshake::client::generate_key())
.header("Connection", "Upgrade")
.header("Upgrade", "websocket")
.header("Sec-WebSocket-Version", "13")
.header("Host", "domain.tld")
// technically not required, but many servers will demand it, so we are basically spoofing that we came from a webpage (can't have path though, just "origin" ...or is it "authority"? Idk I forgor. Don't remember which places `user:password@` goes and goesn't... ¯\_(ツ)_/¯ )
.header("Origin", "https://domain.tld")
.body(())?;
let (mut ws_stream, _) = tokio_tungstenite::client_async_tls(req, tcp).await?; Note all the different variants of urls, don't mix them up. |
Thank you very much! FYI, I don't think you're supposed to include |
@UE2020 you have to include the schema/protocol in a non- |
It's Ok, but do you have any experience with async-socks5 which maybe easier? |
|
But I don't know how to write the code, do you have any example? |
It is based on Tokio 1, but async in current version of rust-websocket is based on legacy Tokio 0.1. |
This Issue is derailed and we are talking about |
To be fair, the README of this crate suggests tungstenite as an alternative. |
Is it possible to proxy a connection using http proxies?
The text was updated successfully, but these errors were encountered: