mirror of
https://github.com/revanced/revanced-integrations.git
synced 2025-01-22 09:47:32 +01:00
fix(YouTube - DeArrow): Correctly handle http status 304
This commit is contained in:
parent
2af3911395
commit
3e380dfce2
@ -28,7 +28,7 @@ import static app.revanced.integrations.shared.StringRef.str;
|
|||||||
* Can show YouTube provided screen captures of beginning/middle/end of the video.
|
* Can show YouTube provided screen captures of beginning/middle/end of the video.
|
||||||
* (ie: sd1.jpg, sd2.jpg, sd3.jpg).
|
* (ie: sd1.jpg, sd2.jpg, sd3.jpg).
|
||||||
* <p>
|
* <p>
|
||||||
* Or can show crowdsourced thumbnails provided by DeArrow (<a href="http://dearrow.ajay.app">...</a>).
|
* Or can show crowd-sourced thumbnails provided by DeArrow (<a href="http://dearrow.ajay.app">...</a>).
|
||||||
* <p>
|
* <p>
|
||||||
* Or can use DeArrow and fall back to screen captures if DeArrow is not available.
|
* Or can use DeArrow and fall back to screen captures if DeArrow is not available.
|
||||||
* <p>
|
* <p>
|
||||||
@ -234,11 +234,18 @@ public final class AlternativeThumbnailsPatch {
|
|||||||
public static void handleCronetSuccess(UrlRequest request, @NonNull UrlResponseInfo responseInfo) {
|
public static void handleCronetSuccess(UrlRequest request, @NonNull UrlResponseInfo responseInfo) {
|
||||||
try {
|
try {
|
||||||
final int statusCode = responseInfo.getHttpStatusCode();
|
final int statusCode = responseInfo.getHttpStatusCode();
|
||||||
if (statusCode != 200) {
|
if (statusCode == 200) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
String url = responseInfo.getUrl();
|
String url = responseInfo.getUrl();
|
||||||
|
|
||||||
if (usingDeArrow() && urlIsDeArrow(url)) {
|
if (usingDeArrow() && urlIsDeArrow(url)) {
|
||||||
Logger.printDebug(() -> "handleCronetSuccess, statusCode: " + statusCode);
|
Logger.printDebug(() -> "handleCronetSuccess, statusCode: " + statusCode);
|
||||||
|
if (statusCode == 304) {
|
||||||
|
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/304
|
||||||
|
return; // Normal response.
|
||||||
|
}
|
||||||
handleDeArrowError(url, statusCode);
|
handleDeArrowError(url, statusCode);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -267,7 +274,6 @@ public final class AlternativeThumbnailsPatch {
|
|||||||
|
|
||||||
VerifiedQualities.setAltThumbnailDoesNotExist(decodedUrl.videoId, quality);
|
VerifiedQualities.setAltThumbnailDoesNotExist(decodedUrl.videoId, quality);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
Logger.printException(() -> "Callback success error", ex);
|
Logger.printException(() -> "Callback success error", ex);
|
||||||
}
|
}
|
||||||
@ -280,7 +286,7 @@ public final class AlternativeThumbnailsPatch {
|
|||||||
* - A non-existent domain.
|
* - A non-existent domain.
|
||||||
* - A url path of something incorrect (ie: /v1/nonExistentEndPoint).
|
* - A url path of something incorrect (ie: /v1/nonExistentEndPoint).
|
||||||
* <p>
|
* <p>
|
||||||
* Known limitation: YT uses an infinite timeout, so this hook is never called if a host never responds.
|
* Cronet uses a very timeout (several minutes), so if the API never responds this hook can take a while to be called.
|
||||||
* But this does not appear to be a problem, as the DeArrow API has not been observed to 'go silent'
|
* But this does not appear to be a problem, as the DeArrow API has not been observed to 'go silent'
|
||||||
* Instead if there's a problem it returns an error code status response, which is handled in this patch.
|
* Instead if there's a problem it returns an error code status response, which is handled in this patch.
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user