7 Commits
dev ... v1.0.3

Author SHA1 Message Date
Colbster937
5453ed0280 fix plugin name on bukkit & bungee 2025-05-08 10:47:41 -05:00
Colbster937
47ab6554c4 Update readme 2025-05-08 10:40:01 -05:00
Colbster937
c076d48e06 use EaglercraftClientBrandEvent instead of EaglercraftLoginEvent 2025-05-08 10:39:53 -05:00
Colbster937
a0ab221ff7 update readme 2025-05-07 19:27:14 -05:00
Colbster937
ec6f618971 better workflow 2025-05-07 19:23:16 -05:00
Colbster937
a417fa7281 fix readme 2025-05-07 19:19:30 -05:00
Colbster937
c62cdb8a7e fix workflow final 2025-05-07 19:19:07 -05:00
7 changed files with 79 additions and 18 deletions

View File

@@ -36,16 +36,29 @@ jobs:
name: OriginBlacklist name: OriginBlacklist
path: build/libs/OriginBlacklist.jar path: build/libs/OriginBlacklist.jar
- name: Extract Version
id: version
run: |
VERSION=$(grep "^version" build.gradle | head -n 1 | cut -d\' -f2)
echo "version=$VERSION" >> "$GITHUB_OUTPUT"
- name: Remove Existing Release
run: |
gh release delete v${{ steps.version.outputs.version }} -y || true
git push origin :refs/tags/v${{ steps.version.outputs.version }} || true
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Create Release - name: Create Release
id: create_release id: create_release
uses: actions/create-release@v1 uses: softprops/action-gh-release@v1
with:
tag_name: v${{ steps.version.outputs.version }}
name: ${{ steps.version.outputs.version }}
draft: false
prerelease: false
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: dev
release_name: dev
draft: true
prerelease: true
- uses: actions/upload-release-asset@v1.0.1 - uses: actions/upload-release-asset@v1.0.1
env: env:
@@ -53,7 +66,7 @@ jobs:
with: with:
upload_url: ${{ steps.create_release.outputs.upload_url }} upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./build/libs/OriginBlacklist.jar asset_path: ./build/libs/OriginBlacklist.jar
asset_name: OriginBlacklist.jar asset_name: OriginBlacklist_${{ steps.version.outputs.version }}.jar
asset_content_type: application/java-archive asset_content_type: application/java-archive
- uses: eregon/publish-release@v1 - uses: eregon/publish-release@v1

View File

@@ -18,9 +18,10 @@ basically just a reimplementation of originblacklist but for eaglerxserver
- [ ] Simple blacklist command - [ ] Simple blacklist command
- [ ] Blacklist -> Whitelist - [ ] Blacklist -> Whitelist
- [ ] IP blacklisting - [ ] IP blacklisting
- [ ] Update system
### Download ### Download
**https://nightly.link/colbster937/originblacklist/workflows/build/main/OriginBlacklist.zip](https://nightly.link/colbster937/originblacklist/workflows/build/main/OriginBlacklist.zip)** **[https://github.com/colbster937/originblacklist/releases/latest/](https://github.com/colbster937/originblacklist/releases/latest/)**
### Building ### Building
``` ```

View File

@@ -8,7 +8,7 @@ plugins {
group = 'dev.colbster937' group = 'dev.colbster937'
version = '1.0.2' version = '1.0.3'
description = 'A reimplementation of OriginBlacklist for EaglerXServer' description = 'A reimplementation of OriginBlacklist for EaglerXServer'
def targetJavaVersion = 17 def targetJavaVersion = 17

View File

@@ -4,7 +4,7 @@ import net.kyori.adventure.text.Component;
import net.kyori.adventure.text.minimessage.MiniMessage; import net.kyori.adventure.text.minimessage.MiniMessage;
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
import net.lax1dude.eaglercraft.backend.server.api.*; import net.lax1dude.eaglercraft.backend.server.api.*;
import net.lax1dude.eaglercraft.backend.server.api.event.IEaglercraftLoginEvent; import net.lax1dude.eaglercraft.backend.server.api.event.IEaglercraftClientBrandEvent;
import net.lax1dude.eaglercraft.backend.server.api.event.IEaglercraftMOTDEvent; import net.lax1dude.eaglercraft.backend.server.api.event.IEaglercraftMOTDEvent;
import net.lax1dude.eaglercraft.backend.server.api.query.IMOTDConnection; import net.lax1dude.eaglercraft.backend.server.api.query.IMOTDConnection;
@@ -34,6 +34,20 @@ public class Base {
api = api1; api = api1;
} }
public static String apiVer = "1.0.2";
public static boolean checkVer(String v1, String v2) {
String[] c = v1.split("\\.");
String[] r = v2.split("\\.");
for (int i = 0; i < Math.max(c.length, r.length); i++) {
int c1 = i < c.length ? Integer.parseInt(c[i]) : 0;
int r1 = i < r.length ? Integer.parseInt(r[i]) : 0;
if (c1 < r1) return false;
if (c1 > r1) return true;
}
return true;
}
public static LoggerAdapter getLogger() { public static LoggerAdapter getLogger() {
if (adapter == null) throw new IllegalStateException("Logger not initialized!"); if (adapter == null) throw new IllegalStateException("Logger not initialized!");
return adapter; return adapter;
@@ -45,8 +59,8 @@ public class Base {
void error(String msg); void error(String msg);
} }
public static void handleConnection(IEaglercraftLoginEvent e) { public static void handleConnection(IEaglercraftClientBrandEvent e) {
IEaglerLoginConnection conn = e.getLoginConnection(); IEaglerPendingConnection conn = e.getPendingConnection();
String origin = conn.getWebSocketHeader(EnumWebSocketHeader.HEADER_ORIGIN); String origin = conn.getWebSocketHeader(EnumWebSocketHeader.HEADER_ORIGIN);
String brand = conn.getEaglerBrandString(); String brand = conn.getEaglerBrandString();
if ((origin != "null" || origin != null) && !config.blacklist.missing_origin) { if ((origin != "null" || origin != null) && !config.blacklist.missing_origin) {

View File

@@ -2,16 +2,29 @@ package dev.colbster937.originblacklist.bukkit;
import dev.colbster937.originblacklist.base.Base; import dev.colbster937.originblacklist.base.Base;
import net.lax1dude.eaglercraft.backend.server.api.bukkit.EaglerXServerAPI; import net.lax1dude.eaglercraft.backend.server.api.bukkit.EaglerXServerAPI;
import net.lax1dude.eaglercraft.backend.server.api.bukkit.event.EaglercraftLoginEvent; import net.lax1dude.eaglercraft.backend.server.api.bukkit.event.EaglercraftClientBrandEvent;
import net.lax1dude.eaglercraft.backend.server.api.bukkit.event.EaglercraftMOTDEvent; import net.lax1dude.eaglercraft.backend.server.api.bukkit.event.EaglercraftMOTDEvent;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import org.bukkit.plugin.Plugin;
public class OriginBlacklistBukkit extends JavaPlugin implements Listener { public class OriginBlacklistBukkit extends JavaPlugin implements Listener {
@Override @Override
public void onEnable() { public void onEnable() {
Plugin plugin = getServer().getPluginManager().getPlugin("EaglercraftXServer");
if (plugin != null) {
String version = plugin.getDescription().getVersion();
if (!Base.checkVer(version, Base.apiVer)) {
getLogger().severe("EaglerXServer " + Base.apiVer + " is required!");
throw new RuntimeException("Incompatible API version");
}
} else {
throw new RuntimeException("Missing EaglerXServer");
}
Base.setLogger(new Base.LoggerAdapter() { Base.setLogger(new Base.LoggerAdapter() {
@Override public void info(String msg) { getLogger().info(msg); } @Override public void info(String msg) { getLogger().info(msg); }
@Override public void warn(String msg) { getLogger().warning(msg); } @Override public void warn(String msg) { getLogger().warning(msg); }
@@ -29,7 +42,7 @@ public class OriginBlacklistBukkit extends JavaPlugin implements Listener {
} }
@EventHandler @EventHandler
public void onLogin(EaglercraftLoginEvent event) { public void onLogin(EaglercraftClientBrandEvent event) {
Base.handleConnection(event); Base.handleConnection(event);
} }

View File

@@ -2,7 +2,7 @@ package dev.colbster937.originblacklist.bungee;
import dev.colbster937.originblacklist.base.Base; import dev.colbster937.originblacklist.base.Base;
import net.lax1dude.eaglercraft.backend.server.api.bungee.EaglerXServerAPI; import net.lax1dude.eaglercraft.backend.server.api.bungee.EaglerXServerAPI;
import net.lax1dude.eaglercraft.backend.server.api.bungee.event.EaglercraftLoginEvent; import net.lax1dude.eaglercraft.backend.server.api.bungee.event.EaglercraftClientBrandEvent;
import net.lax1dude.eaglercraft.backend.server.api.bungee.event.EaglercraftMOTDEvent; import net.lax1dude.eaglercraft.backend.server.api.bungee.event.EaglercraftMOTDEvent;
import net.md_5.bungee.api.plugin.Plugin; import net.md_5.bungee.api.plugin.Plugin;
import net.md_5.bungee.api.plugin.Listener; import net.md_5.bungee.api.plugin.Listener;
@@ -12,6 +12,18 @@ public class OriginBlacklistBungee extends Plugin implements Listener {
@Override @Override
public void onEnable() { public void onEnable() {
Plugin plugin = getProxy().getPluginManager().getPlugin("EaglercraftXServer");
if (plugin != null) {
String version = plugin.getDescription().getVersion();
if (!Base.checkVer(version, Base.apiVer)) {
getLogger().severe("EaglerXServer " + Base.apiVer + " is required!");
throw new RuntimeException("Incompatible API version");
}
} else {
throw new RuntimeException("Missing EaglerXServer");
}
Base.setLogger(new Base.LoggerAdapter() { Base.setLogger(new Base.LoggerAdapter() {
@Override public void info(String msg) { getLogger().info(msg); } @Override public void info(String msg) { getLogger().info(msg); }
@Override public void warn(String msg) { getLogger().warning(msg); } @Override public void warn(String msg) { getLogger().warning(msg); }
@@ -29,7 +41,7 @@ public class OriginBlacklistBungee extends Plugin implements Listener {
} }
@EventHandler @EventHandler
public void onLogin(EaglercraftLoginEvent event) { public void onLogin(EaglercraftClientBrandEvent event) {
Base.handleConnection(event); Base.handleConnection(event);
} }

View File

@@ -6,7 +6,7 @@ import com.velocitypowered.api.event.Subscribe;
import com.velocitypowered.api.proxy.ProxyServer; import com.velocitypowered.api.proxy.ProxyServer;
import dev.colbster937.originblacklist.base.Base; import dev.colbster937.originblacklist.base.Base;
import net.lax1dude.eaglercraft.backend.server.api.velocity.EaglerXServerAPI; import net.lax1dude.eaglercraft.backend.server.api.velocity.EaglerXServerAPI;
import net.lax1dude.eaglercraft.backend.server.api.velocity.event.EaglercraftLoginEvent; import net.lax1dude.eaglercraft.backend.server.api.velocity.event.EaglercraftClientBrandEvent;
import net.lax1dude.eaglercraft.backend.server.api.velocity.event.EaglercraftMOTDEvent; import net.lax1dude.eaglercraft.backend.server.api.velocity.event.EaglercraftMOTDEvent;
import org.slf4j.Logger; import org.slf4j.Logger;
@@ -28,6 +28,14 @@ public class OriginBlacklistVelocity {
@Subscribe @Subscribe
public void onProxyInitialization(ProxyInitializeEvent event) { public void onProxyInitialization(ProxyInitializeEvent event) {
proxy.getPluginManager().getPlugin("eaglerxserver").ifPresentOrElse(plugin -> {
if (!Base.checkVer(plugin.getDescription().getVersion().orElse("1.0.0"), Base.apiVer)) {
logger.error("EaglerXServer " + Base.apiVer + " is required!");
throw new RuntimeException("Incompatible api version");
}
}, () -> {
throw new RuntimeException("Missing EaglerXServer");
});
Base.setApi(EaglerXServerAPI.instance()); Base.setApi(EaglerXServerAPI.instance());
Base.reloadConfig(); Base.reloadConfig();
Base.init(); Base.init();
@@ -36,7 +44,7 @@ public class OriginBlacklistVelocity {
} }
@Subscribe @Subscribe
public void onLogin(EaglercraftLoginEvent event) { public void onLogin(EaglercraftClientBrandEvent event) {
Base.handleConnection(event); Base.handleConnection(event);
} }