1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-12 17:09:00 -05:00

fix(ext/fetch): percent decode userinfo when parsing proxies (#25229)

Fixes #24691
This commit is contained in:
Sean McArthur 2024-08-27 04:48:54 -07:00 committed by Luca Casonato
parent 9fad717c29
commit 27edafa2fe
No known key found for this signature in database
GPG key ID: 01A83EB62563811F

View file

@ -23,6 +23,7 @@ use hyper_util::client::legacy::connect::Connected;
use hyper_util::client::legacy::connect::Connection; use hyper_util::client::legacy::connect::Connection;
use hyper_util::rt::TokioIo; use hyper_util::rt::TokioIo;
use ipnet::IpNet; use ipnet::IpNet;
use percent_encoding::percent_decode_str;
use tokio::net::TcpStream; use tokio::net::TcpStream;
use tokio_rustls::client::TlsStream; use tokio_rustls::client::TlsStream;
use tokio_rustls::TlsConnector; use tokio_rustls::TlsConnector;
@ -192,10 +193,12 @@ impl Target {
if let Some((userinfo, host_port)) = authority.as_str().split_once('@') { if let Some((userinfo, host_port)) = authority.as_str().split_once('@') {
let (user, pass) = userinfo.split_once(':')?; let (user, pass) = userinfo.split_once(':')?;
let user = percent_decode_str(user).decode_utf8_lossy();
let pass = percent_decode_str(pass).decode_utf8_lossy();
if is_socks { if is_socks {
socks_auth = Some((user.into(), pass.into())); socks_auth = Some((user.into(), pass.into()));
} else { } else {
http_auth = Some(basic_auth(user, Some(pass))); http_auth = Some(basic_auth(&user, Some(&pass)));
} }
builder = builder.authority(host_port); builder = builder.authority(host_port);
} else { } else {
@ -773,6 +776,16 @@ fn test_proxy_parse_from_env() {
_ => panic!("bad target"), _ => panic!("bad target"),
} }
// percent encoded user info
match parse("us%2Fer:p%2Fass@127.0.0.1:6666") {
Target::Http { dst, auth } => {
assert_eq!(dst, "http://127.0.0.1:6666");
let auth = auth.unwrap();
assert_eq!(auth.to_str().unwrap(), "Basic dXMvZXI6cC9hc3M=");
}
_ => panic!("bad target"),
}
// socks // socks
match parse("socks5://user:pass@127.0.0.1:6666") { match parse("socks5://user:pass@127.0.0.1:6666") {
Target::Socks { dst, auth } => { Target::Socks { dst, auth } => {