[YouTube] Update client versions and fix a bug when using resetClientVersionAndKey method
The boolean keyAndVersionExtracted in YoutubeParsingHelper was not set to false when resetting the client version and the key, which makes the extractor uses null on the next getting of the client version or the key if the clientVersion and the key were extracted before. Also update client versions.
This commit is contained in:
parent
5a18730845
commit
83f374bff1
|
@ -40,6 +40,7 @@ import java.time.OffsetDateTime;
|
||||||
import java.time.ZoneOffset;
|
import java.time.ZoneOffset;
|
||||||
import java.time.format.DateTimeParseException;
|
import java.time.format.DateTimeParseException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -78,15 +79,15 @@ public final class YoutubeParsingHelper {
|
||||||
|
|
||||||
public static final String YOUTUBEI_V1_URL = "https://www.youtube.com/youtubei/v1/";
|
public static final String YOUTUBEI_V1_URL = "https://www.youtube.com/youtubei/v1/";
|
||||||
|
|
||||||
private static final String HARDCODED_CLIENT_VERSION = "2.20210728.00.00";
|
private static final String HARDCODED_CLIENT_VERSION = "2.20220107.00.00";
|
||||||
private static final String HARDCODED_KEY = "AIzaSyAO_FJ2SlqU8Q4STEHLGCilw_Y9_11qcW8";
|
private static final String HARDCODED_KEY = "AIzaSyAO_FJ2SlqU8Q4STEHLGCilw_Y9_11qcW8";
|
||||||
private static final String MOBILE_YOUTUBE_KEY = "AIzaSyA8eiZmM1FaDVjRy-df2KTyQ_vz_yYM39w";
|
private static final String MOBILE_YOUTUBE_KEY = "AIzaSyA8eiZmM1FaDVjRy-df2KTyQ_vz_yYM39w";
|
||||||
private static final String MOBILE_YOUTUBE_CLIENT_VERSION = "16.29.38";
|
private static final String MOBILE_YOUTUBE_CLIENT_VERSION = "16.49.37";
|
||||||
private static String clientVersion;
|
private static String clientVersion;
|
||||||
private static String key;
|
private static String key;
|
||||||
|
|
||||||
private static final String[] HARDCODED_YOUTUBE_MUSIC_KEY =
|
private static final String[] HARDCODED_YOUTUBE_MUSIC_KEY =
|
||||||
{"AIzaSyC9XL3ZjWddXya6X74dJoCTL-WEYFDNX30", "67", "1.20210726.00.01"};
|
{"AIzaSyC9XL3ZjWddXya6X74dJoCTL-WEYFDNX30", "67", "1.20220103.00.00"};
|
||||||
private static String[] youtubeMusicKey;
|
private static String[] youtubeMusicKey;
|
||||||
|
|
||||||
private static boolean keyAndVersionExtracted = false;
|
private static boolean keyAndVersionExtracted = false;
|
||||||
|
@ -551,40 +552,53 @@ public final class YoutubeParsingHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the client version
|
* Get the client version used by YouTube website on InnerTube requests.
|
||||||
*/
|
*/
|
||||||
public static String getClientVersion() throws IOException, ExtractionException {
|
public static String getClientVersion() throws IOException, ExtractionException {
|
||||||
if (!isNullOrEmpty(clientVersion)) {
|
if (!isNullOrEmpty(clientVersion)) {
|
||||||
return clientVersion;
|
return clientVersion;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extractClientVersionAndKey();
|
||||||
|
|
||||||
|
if (keyAndVersionExtracted) {
|
||||||
|
return clientVersion;
|
||||||
|
} else {
|
||||||
if (areHardcodedClientVersionAndKeyValid()) {
|
if (areHardcodedClientVersionAndKeyValid()) {
|
||||||
clientVersion = HARDCODED_CLIENT_VERSION;
|
clientVersion = HARDCODED_CLIENT_VERSION;
|
||||||
return clientVersion;
|
return clientVersion;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
extractClientVersionAndKey();
|
throw new ExtractionException("Could not get YouTube WEB client version");
|
||||||
return clientVersion;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the key
|
* Get the internal API key used by YouTube website on InnerTube requests.
|
||||||
*/
|
*/
|
||||||
public static String getKey() throws IOException, ExtractionException {
|
public static String getKey() throws IOException, ExtractionException {
|
||||||
if (!isNullOrEmpty(key)) {
|
if (!isNullOrEmpty(key)) {
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extractClientVersionAndKey();
|
||||||
|
|
||||||
|
if (keyAndVersionExtracted) {
|
||||||
|
return key;
|
||||||
|
} else {
|
||||||
if (areHardcodedClientVersionAndKeyValid()) {
|
if (areHardcodedClientVersionAndKeyValid()) {
|
||||||
key = HARDCODED_KEY;
|
key = HARDCODED_KEY;
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
extractClientVersionAndKey();
|
// The ANDROID API key is also valid with the WEB client so return it if we couldn't
|
||||||
return key;
|
// extract the WEB API key.
|
||||||
|
return MOBILE_YOUTUBE_KEY;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>
|
* <p>
|
||||||
* <b>Only use in tests.</b>
|
* <b>Only used in tests.</b>
|
||||||
* </p>
|
* </p>
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -600,11 +614,12 @@ public final class YoutubeParsingHelper {
|
||||||
public static void resetClientVersionAndKey() {
|
public static void resetClientVersionAndKey() {
|
||||||
clientVersion = null;
|
clientVersion = null;
|
||||||
key = null;
|
key = null;
|
||||||
|
keyAndVersionExtracted = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>
|
* <p>
|
||||||
* <b>Only use in tests.</b>
|
* <b>Only used in tests.</b>
|
||||||
* </p>
|
* </p>
|
||||||
*/
|
*/
|
||||||
public static void setNumberGenerator(final Random random) {
|
public static void setNumberGenerator(final Random random) {
|
||||||
|
@ -1128,7 +1143,7 @@ public final class YoutubeParsingHelper {
|
||||||
*/
|
*/
|
||||||
public static void addCookieHeader(@Nonnull final Map<String, List<String>> headers) {
|
public static void addCookieHeader(@Nonnull final Map<String, List<String>> headers) {
|
||||||
if (headers.get("Cookie") == null) {
|
if (headers.get("Cookie") == null) {
|
||||||
headers.put("Cookie", Collections.singletonList(generateConsentCookie()));
|
headers.put("Cookie", Arrays.asList(generateConsentCookie()));
|
||||||
} else {
|
} else {
|
||||||
headers.get("Cookie").add(generateConsentCookie());
|
headers.get("Cookie").add(generateConsentCookie());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue