From 3a1197dd047c07bdcdc37462556c01eecd78362c Mon Sep 17 00:00:00 2001 From: Malloc Voidstar <1284317+AlyoshaVasilieva@users.noreply.github.com> Date: Sat, 10 Jul 2021 10:30:49 -0700 Subject: [PATCH] Imperfectly bypass the GFW The M3U request is definitely being detected but it isn't always being blocked. --- Cargo.lock | 2 +- Cargo.toml | 2 +- src/main.rs | 17 +++++++++-------- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 38bebf9..0838f16 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -116,7 +116,7 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "city17" -version = "0.5.2" +version = "0.5.3" dependencies = [ "once_cell", "pcg_rand", diff --git a/Cargo.toml b/Cargo.toml index 6f4a07f..fb686fa 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "city17" -version = "0.5.2" +version = "0.5.3" authors = ["Malloc Voidstar <1284317+AlyoshaVasilieva@users.noreply.github.com>"] edition = "2018" resolver = "2" diff --git a/src/main.rs b/src/main.rs index c56c770..e22f379 100644 --- a/src/main.rs +++ b/src/main.rs @@ -41,12 +41,11 @@ impl ClientBuilderExt for ClientBuilder { /// /// Doing this appears to reduce latency variation even when the DNS is working. fn insert_resolve_overrides(self) -> Self { - self.resolve("twitch.map.fastly.net", socket_addr_v4([151, 101, 110, 167], 443)) - .resolve("usher.ttvnw.net", socket_addr_v4([23, 160, 0, 254], 443)) - // the fastly IP hasn't changed in the last three years - // the ttvnw IP is also at least two years old - // if they start changing, make it part of the build process - // note alternative usher IP: [192, 108, 239, 254], 443 + self.resolve("fastly.net", socket_addr_v4([151, 101, 110, 167], 443)) + .resolve("usher.ttvnw.net", socket_addr_v4([192, 108, 239, 254], 443)) + // Usher override is unused due to bypass. + // if these IPs start changing, make it part of the build process + // note alternative usher IP: [23, 160, 0, 254], 443 } } @@ -142,9 +141,11 @@ async fn process(var: Variables) -> Result { async fn get_m3u8(url: &str, token: PlaybackAccessToken) -> Result { let mut pcg = get_rng(); let p = pcg.gen_range(0..=9_999_999).to_string(); + // Pretty sure the GFW thinks this is suspicious, but it's not 100% blocked. CLIENT - .get(url) + .get(url.replace("usher.ttvnw.net", "192.108.239.254")) .query(&token.gen_query(&p, &generate_id().to_lowercase())) + .header("Host", "usher.ttvnw.net") .send() .await? .error_for_status()? @@ -211,7 +212,7 @@ async fn get_access_token(var: &Variables) -> Result // This workaround is necessary even with the hard-coded resolver due to TLS SNI // sending the hostname in the clear. CLIENT - .post("https://twitch.map.fastly.net/gql") + .post("https://fastly.net/gql") .header("Host", "gql.twitch.tv") .header("Client-ID", TWITCH_CLIENT) .header("Device-ID", &id)