mirror of
https://github.com/GravitLauncher/Launcher
synced 2025-04-03 23:11:57 +03:00
commit
0595b12c5c
9 changed files with 81 additions and 30 deletions
51
.github/workflows/push.yml
vendored
51
.github/workflows/push.yml
vendored
|
@ -1,6 +1,5 @@
|
||||||
name: push
|
name: push
|
||||||
on:
|
on: push
|
||||||
push:
|
|
||||||
jobs:
|
jobs:
|
||||||
launcher:
|
launcher:
|
||||||
name: Launcher
|
name: Launcher
|
||||||
|
@ -49,31 +48,37 @@ jobs:
|
||||||
name: Launcher
|
name: Launcher
|
||||||
path: artifacts
|
path: artifacts
|
||||||
|
|
||||||
|
- name: Get version value, set to env
|
||||||
|
if: startsWith(github.event.ref, 'refs/tags')
|
||||||
|
run: echo "LAUNCHER_VERSION=$(echo ${{ github.event.ref }} | awk -F\/ '{print $3}')" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Prebuild release files
|
||||||
|
if: startsWith(github.event.ref, 'refs/tags')
|
||||||
|
run: |
|
||||||
|
cd artifacts
|
||||||
|
zip -9 LauncherBase.zip libraries.zip LaunchServer.jar
|
||||||
|
zip -j -9 LaunchServerModules.zip ../modules/*_module/build/libs/*.jar
|
||||||
|
zip -j -9 LauncherModules.zip ../modules/*_lmodule/build/libs/*.jar
|
||||||
|
zip -j -9 ServerWrapperModules.zip ../modules/*_swmodule/build/libs/*.jar
|
||||||
|
|
||||||
- name: Create release
|
- name: Create release
|
||||||
id: create_release
|
id: create_release
|
||||||
uses: actions/create-release@v1
|
uses: softprops/action-gh-release@v1
|
||||||
if: github.event.ref == 'refs/tags/*'
|
if: startsWith(github.event.ref, 'refs/tags')
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
# Список настроек тута: https://github.com/softprops/action-gh-release#-customizing
|
||||||
|
# Можно сделать пуш описания релиза из файла
|
||||||
with:
|
with:
|
||||||
tag_name: ${{ github.ref }}
|
release_name: GravitLauncher ${{ env.LAUNCHER_VERSION }}
|
||||||
release_name: GravitLauncher ${{ github.ref }}
|
|
||||||
draft: false
|
draft: false
|
||||||
prerelease: false
|
prerelease: false
|
||||||
|
files: |
|
||||||
- name: Pack release
|
libraries.zip
|
||||||
if: github.event.ref == 'refs/tags/*'
|
LaunchServer.jar
|
||||||
run: |
|
ServerWrapper.jar
|
||||||
cd artifacts/
|
LauncherAuthlib.jar
|
||||||
zip -r -9 ../Release.zip *
|
LauncherModules.zip
|
||||||
|
LaunchServerModules.zip
|
||||||
- name: Upload release
|
ServerWrapperModules.zip
|
||||||
if: github.event.ref == 'refs/tags/*'
|
LauncherBase.zip
|
||||||
uses: actions/upload-release-asset@v1
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
with:
|
|
||||||
upload_url: ${{ steps.create_release.outputs.upload_url }}
|
|
||||||
asset_path: ./Release.zip
|
|
||||||
asset_name: Release.zip
|
|
||||||
asset_content_type: application/zip
|
|
||||||
|
|
|
@ -58,7 +58,7 @@ public static <T, R> R jsonRequest(T request, String url, String bearerToken, Cl
|
||||||
.header("Accept", "application/json")
|
.header("Accept", "application/json")
|
||||||
.timeout(Duration.ofMillis(10000));
|
.timeout(Duration.ofMillis(10000));
|
||||||
if (bearerToken != null) {
|
if (bearerToken != null) {
|
||||||
request1.header("Authentication", "Bearer ".concat(bearerToken));
|
request1.header("Authorization", "Bearer ".concat(bearerToken));
|
||||||
}
|
}
|
||||||
HttpResponse<InputStream> response = client.send(request1.build(), HttpResponse.BodyHandlers.ofInputStream());
|
HttpResponse<InputStream> response = client.send(request1.build(), HttpResponse.BodyHandlers.ofInputStream());
|
||||||
int statusCode = response.statusCode();
|
int statusCode = response.statusCode();
|
||||||
|
|
|
@ -303,6 +303,9 @@ public PlayerProfile getPlayerProfile(AuthProviderPair pair, User user) {
|
||||||
if (user instanceof UserSupportTextures) {
|
if (user instanceof UserSupportTextures) {
|
||||||
return new PlayerProfile(user.getUUID(), user.getUsername(), ((UserSupportTextures) user).getSkinTexture(), ((UserSupportTextures) user).getCloakTexture());
|
return new PlayerProfile(user.getUUID(), user.getUsername(), ((UserSupportTextures) user).getSkinTexture(), ((UserSupportTextures) user).getCloakTexture());
|
||||||
}
|
}
|
||||||
|
if (pair.textureProvider == null) {
|
||||||
|
throw new NullPointerException("TextureProvider not found");
|
||||||
|
}
|
||||||
return getPlayerProfile(user.getUUID(), user.getUsername(), "", pair.textureProvider);
|
return getPlayerProfile(user.getUUID(), user.getUsername(), "", pair.textureProvider);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,9 +6,9 @@ public final class Version implements Comparable<Version> {
|
||||||
|
|
||||||
public static final int MAJOR = 5;
|
public static final int MAJOR = 5;
|
||||||
public static final int MINOR = 2;
|
public static final int MINOR = 2;
|
||||||
public static final int PATCH = 0;
|
public static final int PATCH = 2;
|
||||||
public static final int BUILD = 1;
|
public static final int BUILD = 1;
|
||||||
public static final Version.Type RELEASE = Type.STABLE;
|
public static final Version.Type RELEASE = Type.DEV;
|
||||||
public final int major;
|
public final int major;
|
||||||
public final int minor;
|
public final int minor;
|
||||||
public final int patch;
|
public final int patch;
|
||||||
|
|
|
@ -29,6 +29,7 @@ public final class JVMHelper {
|
||||||
public static final Runtime RUNTIME = Runtime.getRuntime();
|
public static final Runtime RUNTIME = Runtime.getRuntime();
|
||||||
public static final ClassLoader LOADER = ClassLoader.getSystemClassLoader();
|
public static final ClassLoader LOADER = ClassLoader.getSystemClassLoader();
|
||||||
public static final int JVM_VERSION = getVersion();
|
public static final int JVM_VERSION = getVersion();
|
||||||
|
public static final int JVM_BUILD = getBuild();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
try {
|
try {
|
||||||
|
@ -54,6 +55,25 @@ public static int getVersion() {
|
||||||
return Integer.parseInt(version);
|
return Integer.parseInt(version);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static int getBuild() {
|
||||||
|
String version = System.getProperty("java.version");
|
||||||
|
int dot;
|
||||||
|
if (version.startsWith("1.")) {
|
||||||
|
dot = version.indexOf("_");
|
||||||
|
} else {
|
||||||
|
dot = version.lastIndexOf(".");
|
||||||
|
}
|
||||||
|
if (dot != -1) {
|
||||||
|
version = version.substring(dot + 1);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
return Integer.parseInt(version);
|
||||||
|
} catch (NumberFormatException exception) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public static void appendVars(ProcessBuilder builder, Map<String, String> vars) {
|
public static void appendVars(ProcessBuilder builder, Map<String, String> vars) {
|
||||||
builder.environment().putAll(vars);
|
builder.environment().putAll(vars);
|
||||||
}
|
}
|
||||||
|
|
|
@ -170,12 +170,14 @@ public static class JavaVersion {
|
||||||
public final Path jvmDir;
|
public final Path jvmDir;
|
||||||
public final int version;
|
public final int version;
|
||||||
public final int build;
|
public final int build;
|
||||||
|
public final int bitness;
|
||||||
public boolean enabledJavaFX;
|
public boolean enabledJavaFX;
|
||||||
|
|
||||||
public JavaVersion(Path jvmDir, int version) {
|
public JavaVersion(Path jvmDir, int version) {
|
||||||
this.jvmDir = jvmDir;
|
this.jvmDir = jvmDir;
|
||||||
this.version = version;
|
this.version = version;
|
||||||
this.build = 0;
|
this.build = 0;
|
||||||
|
this.bitness = JVMHelper.OS_BITS;
|
||||||
this.enabledJavaFX = true;
|
this.enabledJavaFX = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -183,11 +185,20 @@ public JavaVersion(Path jvmDir, int version, int build, boolean enabledJavaFX) {
|
||||||
this.jvmDir = jvmDir;
|
this.jvmDir = jvmDir;
|
||||||
this.version = version;
|
this.version = version;
|
||||||
this.build = build;
|
this.build = build;
|
||||||
|
this.bitness = JVMHelper.OS_BITS;
|
||||||
|
this.enabledJavaFX = enabledJavaFX;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JavaVersion(Path jvmDir, int version, int build, int bitness, boolean enabledJavaFX) {
|
||||||
|
this.jvmDir = jvmDir;
|
||||||
|
this.version = version;
|
||||||
|
this.build = build;
|
||||||
|
this.bitness = bitness;
|
||||||
this.enabledJavaFX = enabledJavaFX;
|
this.enabledJavaFX = enabledJavaFX;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static JavaVersion getCurrentJavaVersion() {
|
public static JavaVersion getCurrentJavaVersion() {
|
||||||
return new JavaVersion(Paths.get(System.getProperty("java.home")), JVMHelper.getVersion(), 0, isCurrentJavaSupportJavaFX());
|
return new JavaVersion(Paths.get(System.getProperty("java.home")), JVMHelper.getVersion(), JVMHelper.JVM_BUILD, JVMHelper.JVM_BITS, isCurrentJavaSupportJavaFX());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isCurrentJavaSupportJavaFX() {
|
private static boolean isCurrentJavaSupportJavaFX() {
|
||||||
|
@ -212,14 +223,21 @@ public static JavaVersion getByPath(Path jvmDir) throws IOException {
|
||||||
}
|
}
|
||||||
Path releaseFile = jvmDir.resolve("release");
|
Path releaseFile = jvmDir.resolve("release");
|
||||||
JavaVersionAndBuild versionAndBuild;
|
JavaVersionAndBuild versionAndBuild;
|
||||||
|
int bitness = JVMHelper.OS_BITS;
|
||||||
if (IOHelper.isFile(releaseFile)) {
|
if (IOHelper.isFile(releaseFile)) {
|
||||||
Properties properties = new Properties();
|
Properties properties = new Properties();
|
||||||
properties.load(IOHelper.newReader(releaseFile));
|
properties.load(IOHelper.newReader(releaseFile));
|
||||||
versionAndBuild = getJavaVersion(properties.getProperty("JAVA_VERSION").replaceAll("\"", ""));
|
versionAndBuild = getJavaVersion(properties.getProperty("JAVA_VERSION").replaceAll("\"", ""));
|
||||||
|
String arch = properties.getProperty("JAVA_VERSION").replaceAll("\"", "");
|
||||||
|
if (arch.contains("x86_64")) {
|
||||||
|
bitness = 64;
|
||||||
|
} else if (arch.contains("x86") || arch.contains("x32")) {
|
||||||
|
bitness = 32;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
versionAndBuild = new JavaVersionAndBuild(isExistExtJavaLibrary(jvmDir, "jfxrt") ? 8 : 9, 0);
|
versionAndBuild = new JavaVersionAndBuild(isExistExtJavaLibrary(jvmDir, "jfxrt") ? 8 : 9, 0);
|
||||||
}
|
}
|
||||||
JavaVersion resultJavaVersion = new JavaVersion(jvmDir, versionAndBuild.version, versionAndBuild.build, false);
|
JavaVersion resultJavaVersion = new JavaVersion(jvmDir, versionAndBuild.version, versionAndBuild.build, bitness, false);
|
||||||
if (versionAndBuild.version <= 8) {
|
if (versionAndBuild.version <= 8) {
|
||||||
resultJavaVersion.enabledJavaFX = isExistExtJavaLibrary(jvmDir, "jfxrt");
|
resultJavaVersion.enabledJavaFX = isExistExtJavaLibrary(jvmDir, "jfxrt");
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -29,6 +29,7 @@ public final class JVMHelper {
|
||||||
public static final Runtime RUNTIME = Runtime.getRuntime();
|
public static final Runtime RUNTIME = Runtime.getRuntime();
|
||||||
public static final ClassLoader LOADER = ClassLoader.getSystemClassLoader();
|
public static final ClassLoader LOADER = ClassLoader.getSystemClassLoader();
|
||||||
public static final int JVM_VERSION = getVersion();
|
public static final int JVM_VERSION = getVersion();
|
||||||
|
public static final int JVM_BUILD = getBuild();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
try {
|
try {
|
||||||
|
@ -46,6 +47,10 @@ public static int getVersion() {
|
||||||
return Runtime.version().feature();
|
return Runtime.version().feature();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static int getBuild() {
|
||||||
|
return Runtime.version().update();
|
||||||
|
}
|
||||||
|
|
||||||
public static void appendVars(ProcessBuilder builder, Map<String, String> vars) {
|
public static void appendVars(ProcessBuilder builder, Map<String, String> vars) {
|
||||||
builder.environment().putAll(vars);
|
builder.environment().putAll(vars);
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
id 'org.openjfx.javafxplugin' version '0.0.10' apply false
|
id 'org.openjfx.javafxplugin' version '0.0.10' apply false
|
||||||
}
|
}
|
||||||
group = 'pro.gravit.launcher'
|
group = 'pro.gravit.launcher'
|
||||||
version = '5.2.0'
|
version = '5.2.2-SNAPSHOT'
|
||||||
|
|
||||||
apply from: 'props.gradle'
|
apply from: 'props.gradle'
|
||||||
|
|
||||||
|
|
2
modules
2
modules
|
@ -1 +1 @@
|
||||||
Subproject commit 929428a7438aeb9a3f90c69a881da43030113e1a
|
Subproject commit 84a5599243bddf0f7a8081cc7f5672e9140893bd
|
Loading…
Reference in a new issue