[CI-SKIP] Update version checker to use V2 downloads API (#5728)

This commit is contained in:
Prof-Bloodstone 2021-05-27 15:25:24 +02:00
parent 2667fd04c4
commit 152c94320f

View File

@ -24,6 +24,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+import java.io.*; +import java.io.*;
+import java.net.HttpURLConnection; +import java.net.HttpURLConnection;
+import java.net.URL; +import java.net.URL;
+import java.util.stream.StreamSupport;
+ +
+public class PaperVersionFetcher implements VersionFetcher { +public class PaperVersionFetcher implements VersionFetcher {
+ private static final java.util.regex.Pattern VER_PATTERN = java.util.regex.Pattern.compile("^([0-9\\.]*)\\-.*R"); // R is an anchor, will always give '-R' at end + private static final java.util.regex.Pattern VER_PATTERN = java.util.regex.Pattern.compile("^([0-9\\.]*)\\-.*R"); // R is an anchor, will always give '-R' at end
@ -84,11 +85,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
+ if (siteApiVersion == null) { return -1; } + if (siteApiVersion == null) { return -1; }
+ try { + try {
+ try (BufferedReader reader = Resources.asCharSource( + try (BufferedReader reader = Resources.asCharSource(
+ new URL("https://papermc.io/api/v1/paper/" + siteApiVersion + "/latest"), + new URL("https://papermc.io/api/v2/projects/paper/versions/" + siteApiVersion),
+ Charsets.UTF_8 + Charsets.UTF_8
+ ).openBufferedStream()) { + ).openBufferedStream()) {
+ JsonObject json = new Gson().fromJson(reader, JsonObject.class); + JsonObject json = new Gson().fromJson(reader, JsonObject.class);
+ int latest = json.get("build").getAsInt(); + JsonArray builds = json.getAsJsonArray("builds");
+ int latest = StreamSupport.stream(builds.spliterator(), false)
+ .mapToInt(e -> e.getAsInt())
+ .max()
+ .getAsInt();
+ return latest - jenkinsBuild; + return latest - jenkinsBuild;
+ } catch (JsonSyntaxException ex) { + } catch (JsonSyntaxException ex) {
+ ex.printStackTrace(); + ex.printStackTrace();