From a92c7b2fa46387ff3f4ba5adeab43f79d9796005 Mon Sep 17 00:00:00 2001 From: LisoUseInAIKyrios <118716522+LisoUseInAIKyrios@users.noreply.github.com> Date: Tue, 10 Dec 2024 21:12:38 +0400 Subject: [PATCH] refactor(YouTube - Spoof streaming data): Add more debug logging --- .../spoof/requests/StreamingDataRequest.java | 41 +++++++++++-------- 1 file changed, 24 insertions(+), 17 deletions(-) diff --git a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java index 885372230..9c1ae7421 100644 --- a/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java +++ b/extensions/shared/library/src/main/java/app/revanced/extension/shared/spoof/requests/StreamingDataRequest.java @@ -115,8 +115,7 @@ public class StreamingDataRequest { Objects.requireNonNull(playerHeaders); final long startTime = System.currentTimeMillis(); - String clientTypeName = clientType.name(); - Logger.printDebug(() -> "Fetching video streams for: " + videoId + " using client: " + clientType.name()); + Logger.printDebug(() -> "Fetching video streams for: " + videoId + " using client: " + clientType); try { HttpURLConnection connection = PlayerRoutes.getPlayerResponseConnectionFromRoute(GET_STREAMING_DATA, clientType); @@ -124,12 +123,16 @@ public class StreamingDataRequest { connection.setReadTimeout(HTTP_TIMEOUT_MILLISECONDS); for (String key : REQUEST_HEADER_KEYS) { - if (!clientType.canLogin && key.equals(AUTHORIZATION_HEADER)) { - continue; - } - String value = playerHeaders.get(key); if (value != null) { + if (key.equals(AUTHORIZATION_HEADER)) { + if (!clientType.canLogin) { + Logger.printDebug(() -> "Not including request header: " + key); + continue; + } + } + + Logger.printDebug(() -> "Including request header: " + key); connection.setRequestProperty(key, value); } } @@ -142,8 +145,10 @@ public class StreamingDataRequest { final int responseCode = connection.getResponseCode(); if (responseCode == 200) return connection; - handleConnectionError(clientTypeName + " not available with response code: " - + responseCode + " message: " + connection.getResponseMessage(), + // This situation likely means the patches are outdated. + // Use a toast message that suggests updating. + handleConnectionError("Playback error (App is outdated?) " + clientType + ": " + + responseCode + " response: " + connection.getResponseMessage(), null, showErrorToasts); } catch (SocketTimeoutException ex) { handleConnectionError("Connection timeout", ex, showErrorToasts); @@ -172,17 +177,19 @@ public class StreamingDataRequest { try { // gzip encoding doesn't response with content length (-1), // but empty response body does. - if (connection.getContentLength() != 0) { - try (InputStream inputStream = new BufferedInputStream(connection.getInputStream())) { - try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) { - byte[] buffer = new byte[2048]; - int bytesRead; - while ((bytesRead = inputStream.read(buffer)) >= 0) { - baos.write(buffer, 0, bytesRead); - } + if (connection.getContentLength() == 0) { + Logger.printDebug(() -> "Received empty response for video: " + videoId); + } else { + try (InputStream inputStream = new BufferedInputStream(connection.getInputStream()); + ByteArrayOutputStream baos = new ByteArrayOutputStream()) { - return ByteBuffer.wrap(baos.toByteArray()); + byte[] buffer = new byte[2048]; + int bytesRead; + while ((bytesRead = inputStream.read(buffer)) >= 0) { + baos.write(buffer, 0, bytesRead); } + + return ByteBuffer.wrap(baos.toByteArray()); } } } catch (IOException ex) {