mirror of
https://github.com/plexusorg/Plex.git
synced 2025-01-12 01:34:02 +00:00
Merge branch 'master' into punishments
This commit is contained in:
commit
08bdeaac48
@ -37,37 +37,27 @@ import org.bukkit.plugin.java.JavaPlugin;
|
|||||||
@Setter
|
@Setter
|
||||||
public class Plex extends JavaPlugin
|
public class Plex extends JavaPlugin
|
||||||
{
|
{
|
||||||
|
public static final BuildProperties build = new BuildProperties();
|
||||||
private static Plex plugin;
|
private static Plex plugin;
|
||||||
public Config config;
|
public Config config;
|
||||||
public Config messages;
|
public Config messages;
|
||||||
public Config indefBans;
|
public Config indefBans;
|
||||||
|
|
||||||
public File modulesFolder;
|
public File modulesFolder;
|
||||||
|
|
||||||
private StorageType storageType = StorageType.SQLITE;
|
private StorageType storageType = StorageType.SQLITE;
|
||||||
|
|
||||||
private SQLConnection sqlConnection;
|
private SQLConnection sqlConnection;
|
||||||
private MongoConnection mongoConnection;
|
private MongoConnection mongoConnection;
|
||||||
private RedisConnection redisConnection;
|
private RedisConnection redisConnection;
|
||||||
|
|
||||||
private MongoPlayerData mongoPlayerData;
|
private MongoPlayerData mongoPlayerData;
|
||||||
private SQLPlayerData sqlPlayerData;
|
private SQLPlayerData sqlPlayerData;
|
||||||
private SQLPunishment sqlPunishment;
|
private SQLPunishment sqlPunishment;
|
||||||
|
|
||||||
private ModuleManager moduleManager;
|
private ModuleManager moduleManager;
|
||||||
private RankManager rankManager;
|
private RankManager rankManager;
|
||||||
private ServiceManager serviceManager;
|
private ServiceManager serviceManager;
|
||||||
|
|
||||||
private PunishmentManager punishmentManager;
|
private PunishmentManager punishmentManager;
|
||||||
|
|
||||||
private AdminList adminList;
|
private AdminList adminList;
|
||||||
|
|
||||||
private UpdateChecker updateChecker;
|
private UpdateChecker updateChecker;
|
||||||
|
|
||||||
private String system;
|
private String system;
|
||||||
|
|
||||||
public static final BuildProperties build = new BuildProperties();
|
|
||||||
|
|
||||||
public static Plex get()
|
public static Plex get()
|
||||||
{
|
{
|
||||||
return plugin;
|
return plugin;
|
||||||
|
@ -25,7 +25,8 @@ import java.util.stream.Collectors;
|
|||||||
* @see Admin
|
* @see Admin
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class AdminList extends PlexBase {
|
public class AdminList extends PlexBase
|
||||||
|
{
|
||||||
/**
|
/**
|
||||||
* Key/Value storage, where the key is the unique ID of the admin
|
* Key/Value storage, where the key is the unique ID of the admin
|
||||||
*/
|
*/
|
||||||
@ -36,7 +37,8 @@ public class AdminList extends PlexBase {
|
|||||||
*
|
*
|
||||||
* @param admin The admin object
|
* @param admin The admin object
|
||||||
*/
|
*/
|
||||||
public void addToCache(Admin admin) {
|
public void addToCache(Admin admin)
|
||||||
|
{
|
||||||
admins.put(admin.getUuid(), admin);
|
admins.put(admin.getUuid(), admin);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,7 +48,8 @@ public class AdminList extends PlexBase {
|
|||||||
* @param uuid The unique ID of the admin
|
* @param uuid The unique ID of the admin
|
||||||
* @see UUID
|
* @see UUID
|
||||||
*/
|
*/
|
||||||
public void removeFromCache(UUID uuid) {
|
public void removeFromCache(UUID uuid)
|
||||||
|
{
|
||||||
admins.remove(uuid);
|
admins.remove(uuid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,24 +58,32 @@ public class AdminList extends PlexBase {
|
|||||||
*
|
*
|
||||||
* @return An array list of the names of every admin
|
* @return An array list of the names of every admin
|
||||||
*/
|
*/
|
||||||
public List<String> getAllAdmins() {
|
public List<String> getAllAdmins()
|
||||||
|
{
|
||||||
List<String> admins = Lists.newArrayList();
|
List<String> admins = Lists.newArrayList();
|
||||||
if (plugin.getStorageType() == StorageType.MONGODB) {
|
if (plugin.getStorageType() == StorageType.MONGODB)
|
||||||
|
{
|
||||||
Datastore store = plugin.getMongoConnection().getDatastore();
|
Datastore store = plugin.getMongoConnection().getDatastore();
|
||||||
Query<PlexPlayer> query = store.find(PlexPlayer.class);
|
Query<PlexPlayer> query = store.find(PlexPlayer.class);
|
||||||
admins.addAll(query.stream().filter(plexPlayer -> plexPlayer.getRankFromString().isAtLeast(Rank.ADMIN)).map(PlexPlayer::getName).collect(Collectors.toList()));
|
admins.addAll(query.stream().filter(plexPlayer -> plexPlayer.getRankFromString().isAtLeast(Rank.ADMIN)).map(PlexPlayer::getName).collect(Collectors.toList()));
|
||||||
} else {
|
}
|
||||||
try (Connection con = plugin.getSqlConnection().getCon()) {
|
else
|
||||||
|
{
|
||||||
|
try (Connection con = plugin.getSqlConnection().getCon())
|
||||||
|
{
|
||||||
PreparedStatement statement = con.prepareStatement("SELECT * FROM `players` WHERE rank IN(?, ?, ?)");
|
PreparedStatement statement = con.prepareStatement("SELECT * FROM `players` WHERE rank IN(?, ?, ?)");
|
||||||
statement.setString(1, Rank.ADMIN.name().toLowerCase());
|
statement.setString(1, Rank.ADMIN.name().toLowerCase());
|
||||||
statement.setString(2, Rank.SENIOR_ADMIN.name().toLowerCase());
|
statement.setString(2, Rank.SENIOR_ADMIN.name().toLowerCase());
|
||||||
statement.setString(3, Rank.EXECUTIVE.name().toLowerCase());
|
statement.setString(3, Rank.EXECUTIVE.name().toLowerCase());
|
||||||
|
|
||||||
ResultSet set = statement.executeQuery();
|
ResultSet set = statement.executeQuery();
|
||||||
while (set.next()) {
|
while (set.next())
|
||||||
|
{
|
||||||
admins.add(set.getString("name"));
|
admins.add(set.getString("name"));
|
||||||
}
|
}
|
||||||
} catch (SQLException throwables) {
|
}
|
||||||
|
catch (SQLException throwables)
|
||||||
|
{
|
||||||
throwables.printStackTrace();
|
throwables.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -84,21 +95,27 @@ public class AdminList extends PlexBase {
|
|||||||
*
|
*
|
||||||
* @return An array list of the names of every admin
|
* @return An array list of the names of every admin
|
||||||
*/
|
*/
|
||||||
public List<PlexPlayer> getAllAdminPlayers() {
|
public List<PlexPlayer> getAllAdminPlayers()
|
||||||
|
{
|
||||||
List<PlexPlayer> plexPlayers = Lists.newArrayList();
|
List<PlexPlayer> plexPlayers = Lists.newArrayList();
|
||||||
if (plugin.getStorageType() == StorageType.MONGODB) {
|
if (plugin.getStorageType() == StorageType.MONGODB)
|
||||||
|
{
|
||||||
Datastore store = plugin.getMongoConnection().getDatastore();
|
Datastore store = plugin.getMongoConnection().getDatastore();
|
||||||
Query<PlexPlayer> query = store.find(PlexPlayer.class);
|
Query<PlexPlayer> query = store.find(PlexPlayer.class);
|
||||||
return query.stream().toList().stream().filter(player -> plugin.getRankManager().isAdmin(player)).collect(Collectors.toList());
|
return query.stream().toList().stream().filter(player -> plugin.getRankManager().isAdmin(player)).collect(Collectors.toList());
|
||||||
} else {
|
}
|
||||||
try (Connection con = plugin.getSqlConnection().getCon()) {
|
else
|
||||||
|
{
|
||||||
|
try (Connection con = plugin.getSqlConnection().getCon())
|
||||||
|
{
|
||||||
PreparedStatement statement = con.prepareStatement("SELECT * FROM `players` WHERE rank IN(?, ?, ?)");
|
PreparedStatement statement = con.prepareStatement("SELECT * FROM `players` WHERE rank IN(?, ?, ?)");
|
||||||
statement.setString(1, Rank.ADMIN.name().toLowerCase());
|
statement.setString(1, Rank.ADMIN.name().toLowerCase());
|
||||||
statement.setString(2, Rank.SENIOR_ADMIN.name().toLowerCase());
|
statement.setString(2, Rank.SENIOR_ADMIN.name().toLowerCase());
|
||||||
statement.setString(3, Rank.EXECUTIVE.name().toLowerCase());
|
statement.setString(3, Rank.EXECUTIVE.name().toLowerCase());
|
||||||
|
|
||||||
ResultSet set = statement.executeQuery();
|
ResultSet set = statement.executeQuery();
|
||||||
while (set.next()) {
|
while (set.next())
|
||||||
|
{
|
||||||
String uuid = set.getString("uuid");
|
String uuid = set.getString("uuid");
|
||||||
String name = set.getString("name");
|
String name = set.getString("name");
|
||||||
String loginMSG = set.getString("login_msg");
|
String loginMSG = set.getString("login_msg");
|
||||||
@ -107,7 +124,8 @@ public class AdminList extends PlexBase {
|
|||||||
long coins = set.getLong("coins");
|
long coins = set.getLong("coins");
|
||||||
boolean vanished = set.getBoolean("vanished");
|
boolean vanished = set.getBoolean("vanished");
|
||||||
boolean commandspy = set.getBoolean("commandspy");
|
boolean commandspy = set.getBoolean("commandspy");
|
||||||
List<String> ips = new Gson().fromJson(set.getString("ips"), new TypeToken<List<String>>() {
|
List<String> ips = new Gson().fromJson(set.getString("ips"), new TypeToken<List<String>>()
|
||||||
|
{
|
||||||
}.getType());
|
}.getType());
|
||||||
|
|
||||||
PlexPlayer plexPlayer = new PlexPlayer(UUID.fromString(uuid));
|
PlexPlayer plexPlayer = new PlexPlayer(UUID.fromString(uuid));
|
||||||
@ -121,7 +139,9 @@ public class AdminList extends PlexBase {
|
|||||||
plexPlayer.setCommandSpy(commandspy);
|
plexPlayer.setCommandSpy(commandspy);
|
||||||
plexPlayers.add(plexPlayer);
|
plexPlayers.add(plexPlayer);
|
||||||
}
|
}
|
||||||
} catch (SQLException throwables) {
|
}
|
||||||
|
catch (SQLException throwables)
|
||||||
|
{
|
||||||
throwables.printStackTrace();
|
throwables.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,15 +39,15 @@ public class UnbanCMD extends PlexCommand
|
|||||||
if (args.length == 1)
|
if (args.length == 1)
|
||||||
{
|
{
|
||||||
UUID targetUUID = PlexUtils.getFromName(args[0]);
|
UUID targetUUID = PlexUtils.getFromName(args[0]);
|
||||||
PlexPlayer plexPlayer = getOfflinePlexPlayer(targetUUID);
|
|
||||||
|
|
||||||
if (!DataUtils.hasPlayedBefore(targetUUID))
|
if (targetUUID == null || !DataUtils.hasPlayedBefore(targetUUID))
|
||||||
{
|
{
|
||||||
throw new PlayerNotFoundException();
|
throw new PlayerNotFoundException();
|
||||||
}
|
}
|
||||||
|
|
||||||
plugin.getPunishmentManager().isAsyncBanned(targetUUID).whenComplete((aBoolean, throwable) ->
|
plugin.getPunishmentManager().isAsyncBanned(targetUUID).whenComplete((aBoolean, throwable) ->
|
||||||
{
|
{
|
||||||
|
PlexPlayer plexPlayer = getOfflinePlexPlayer(targetUUID);
|
||||||
if (!aBoolean)
|
if (!aBoolean)
|
||||||
{
|
{
|
||||||
send(sender, MiniMessage.miniMessage().deserialize(new PlayerNotBannedException().getMessage()));
|
send(sender, MiniMessage.miniMessage().deserialize(new PlayerNotBannedException().getMessage()));
|
||||||
|
@ -27,7 +27,10 @@ public class TabListener extends PlexListener
|
|||||||
{
|
{
|
||||||
PlexPlayer plexPlayer = event.getPlexPlayer();
|
PlexPlayer plexPlayer = event.getPlexPlayer();
|
||||||
Player player = event.getPlexPlayer().getPlayer();
|
Player player = event.getPlexPlayer().getPlayer();
|
||||||
if (player == null) return;
|
if (player == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
player.playerListName(Component.text(player.getName()).color(plugin.getRankManager().getColor(plexPlayer)));
|
player.playerListName(Component.text(player.getName()).color(plugin.getRankManager().getColor(plexPlayer)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -36,7 +39,10 @@ public class TabListener extends PlexListener
|
|||||||
{
|
{
|
||||||
PlexPlayer plexPlayer = event.getPlexPlayer();
|
PlexPlayer plexPlayer = event.getPlexPlayer();
|
||||||
Player player = event.getPlexPlayer().getPlayer();
|
Player player = event.getPlexPlayer().getPlayer();
|
||||||
if (player == null) return;
|
if (player == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
player.playerListName(Component.text(player.getName()).color(plugin.getRankManager().getColor(plexPlayer)));
|
player.playerListName(Component.text(player.getName()).color(plugin.getRankManager().getColor(plexPlayer)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -45,7 +51,10 @@ public class TabListener extends PlexListener
|
|||||||
{
|
{
|
||||||
PlexPlayer plexPlayer = event.getPlexPlayer();
|
PlexPlayer plexPlayer = event.getPlexPlayer();
|
||||||
Player player = event.getPlexPlayer().getPlayer();
|
Player player = event.getPlexPlayer().getPlayer();
|
||||||
if (player == null) return;
|
if (player == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
player.playerListName(Component.text(player.getName()).color(plugin.getRankManager().getColor(plexPlayer)));
|
player.playerListName(Component.text(player.getName()).color(plugin.getRankManager().getColor(plexPlayer)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,13 @@ import com.google.common.collect.Lists;
|
|||||||
import dev.plex.Plex;
|
import dev.plex.Plex;
|
||||||
import dev.plex.command.PlexCommand;
|
import dev.plex.command.PlexCommand;
|
||||||
import dev.plex.listener.PlexListener;
|
import dev.plex.listener.PlexListener;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
import lombok.AccessLevel;
|
import lombok.AccessLevel;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
@ -12,17 +19,10 @@ import org.bukkit.event.HandlerList;
|
|||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.net.URLConnection;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Locale;
|
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
@Setter(AccessLevel.MODULE)
|
@Setter(AccessLevel.MODULE)
|
||||||
public abstract class PlexModule {
|
public abstract class PlexModule
|
||||||
|
{
|
||||||
@Getter(AccessLevel.MODULE)
|
@Getter(AccessLevel.MODULE)
|
||||||
private final List<PlexCommand> commands = Lists.newArrayList();
|
private final List<PlexCommand> commands = Lists.newArrayList();
|
||||||
|
|
||||||
@ -34,48 +34,61 @@ public abstract class PlexModule {
|
|||||||
private File dataFolder;
|
private File dataFolder;
|
||||||
private Logger logger;
|
private Logger logger;
|
||||||
|
|
||||||
public void load() {
|
public void load()
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public void enable() {
|
public void enable()
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public void disable() {
|
public void disable()
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerListener(PlexListener listener) {
|
public void registerListener(PlexListener listener)
|
||||||
|
{
|
||||||
listeners.add(listener);
|
listeners.add(listener);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void unregisterListener(PlexListener listener) {
|
public void unregisterListener(PlexListener listener)
|
||||||
|
{
|
||||||
listeners.remove(listener);
|
listeners.remove(listener);
|
||||||
HandlerList.unregisterAll(listener);
|
HandlerList.unregisterAll(listener);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerCommand(PlexCommand command) {
|
public void registerCommand(PlexCommand command)
|
||||||
|
{
|
||||||
commands.add(command);
|
commands.add(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void unregisterCommand(PlexCommand command) {
|
public void unregisterCommand(PlexCommand command)
|
||||||
|
{
|
||||||
commands.remove(command);
|
commands.remove(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
public PlexCommand getCommand(String name) {
|
public PlexCommand getCommand(String name)
|
||||||
|
{
|
||||||
return commands.stream().filter(plexCommand -> plexCommand.getName().equalsIgnoreCase(name) || plexCommand.getAliases().stream().map(String::toLowerCase).toList().contains(name.toLowerCase(Locale.ROOT))).findFirst().orElse(null);
|
return commands.stream().filter(plexCommand -> plexCommand.getName().equalsIgnoreCase(name) || plexCommand.getAliases().stream().map(String::toLowerCase).toList().contains(name.toLowerCase(Locale.ROOT))).findFirst().orElse(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public InputStream getResource(@NotNull String filename) {
|
public InputStream getResource(@NotNull String filename)
|
||||||
try {
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
URL url = this.getClass().getClassLoader().getResource(filename);
|
URL url = this.getClass().getClassLoader().getResource(filename);
|
||||||
if (url == null) {
|
if (url == null)
|
||||||
|
{
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
URLConnection connection = url.openConnection();
|
URLConnection connection = url.openConnection();
|
||||||
connection.setUseCaches(false);
|
connection.setUseCaches(false);
|
||||||
return connection.getInputStream();
|
return connection.getInputStream();
|
||||||
} catch (IOException ex) {
|
}
|
||||||
|
catch (IOException ex)
|
||||||
|
{
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,8 @@ import java.nio.file.Files;
|
|||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.StandardCopyOption;
|
import java.nio.file.StandardCopyOption;
|
||||||
|
|
||||||
public class CustomClassLoader extends URLClassLoader {
|
public class CustomClassLoader extends URLClassLoader
|
||||||
|
{
|
||||||
/*public CustomClassLoader(URL[] urls, ClassLoader parent) {
|
/*public CustomClassLoader(URL[] urls, ClassLoader parent) {
|
||||||
super(urls, parent);
|
super(urls, parent);
|
||||||
for (URL url : urls) {
|
for (URL url : urls) {
|
||||||
@ -17,25 +18,30 @@ public class CustomClassLoader extends URLClassLoader {
|
|||||||
}
|
}
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
public CustomClassLoader(URL jarInJar, ClassLoader parent) {
|
public CustomClassLoader(URL jarInJar, ClassLoader parent)
|
||||||
|
{
|
||||||
super(new URL[]{extractJar(jarInJar)}, parent);
|
super(new URL[]{extractJar(jarInJar)}, parent);
|
||||||
addURL(jarInJar);
|
addURL(jarInJar);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static URL extractJar(URL jarInJar) throws RuntimeException
|
||||||
static URL extractJar(URL jarInJar) throws RuntimeException {
|
{
|
||||||
// get the jar-in-jar resource
|
// get the jar-in-jar resource
|
||||||
if (jarInJar == null) {
|
if (jarInJar == null)
|
||||||
|
{
|
||||||
throw new RuntimeException("Could not locate jar-in-jar");
|
throw new RuntimeException("Could not locate jar-in-jar");
|
||||||
}
|
}
|
||||||
|
|
||||||
// create a temporary file
|
// create a temporary file
|
||||||
// on posix systems by default this is only read/writable by the process owner
|
// on posix systems by default this is only read/writable by the process owner
|
||||||
Path path;
|
Path path;
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
path = Files.createTempFile("plex-jarinjar", ".jar.tmp");
|
path = Files.createTempFile("plex-jarinjar", ".jar.tmp");
|
||||||
} catch (IOException e) {
|
}
|
||||||
|
catch (IOException e)
|
||||||
|
{
|
||||||
throw new RuntimeException("Unable to create a temporary file", e);
|
throw new RuntimeException("Unable to create a temporary file", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -43,15 +49,21 @@ public class CustomClassLoader extends URLClassLoader {
|
|||||||
path.toFile().deleteOnExit();
|
path.toFile().deleteOnExit();
|
||||||
|
|
||||||
// copy the jar-in-jar to the temporary file path
|
// copy the jar-in-jar to the temporary file path
|
||||||
try (InputStream in = jarInJar.openStream()) {
|
try (InputStream in = jarInJar.openStream())
|
||||||
|
{
|
||||||
Files.copy(in, path, StandardCopyOption.REPLACE_EXISTING);
|
Files.copy(in, path, StandardCopyOption.REPLACE_EXISTING);
|
||||||
} catch (IOException e) {
|
}
|
||||||
|
catch (IOException e)
|
||||||
|
{
|
||||||
throw new RuntimeException("Unable to copy jar-in-jar to temporary path", e);
|
throw new RuntimeException("Unable to copy jar-in-jar to temporary path", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
return path.toUri().toURL();
|
return path.toUri().toURL();
|
||||||
} catch (MalformedURLException e) {
|
}
|
||||||
|
catch (MalformedURLException e)
|
||||||
|
{
|
||||||
throw new RuntimeException("Unable to get URL from path", e);
|
throw new RuntimeException("Unable to get URL from path", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,14 +45,16 @@ import org.jetbrains.annotations.Nullable;
|
|||||||
|
|
||||||
//TODO: doesn't work
|
//TODO: doesn't work
|
||||||
|
|
||||||
public class LibraryLoader {
|
public class LibraryLoader
|
||||||
|
{
|
||||||
|
|
||||||
private final Logger logger;
|
private final Logger logger;
|
||||||
private final RepositorySystem repository;
|
private final RepositorySystem repository;
|
||||||
private final DefaultRepositorySystemSession session;
|
private final DefaultRepositorySystemSession session;
|
||||||
private final List<RemoteRepository> repositories;
|
private final List<RemoteRepository> repositories;
|
||||||
|
|
||||||
public LibraryLoader(@NotNull Logger logger) {
|
public LibraryLoader(@NotNull Logger logger)
|
||||||
|
{
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
|
|
||||||
DefaultServiceLocator locator = MavenRepositorySystemUtils.newServiceLocator();
|
DefaultServiceLocator locator = MavenRepositorySystemUtils.newServiceLocator();
|
||||||
@ -64,9 +66,11 @@ public class LibraryLoader {
|
|||||||
|
|
||||||
session.setChecksumPolicy(RepositoryPolicy.CHECKSUM_POLICY_FAIL);
|
session.setChecksumPolicy(RepositoryPolicy.CHECKSUM_POLICY_FAIL);
|
||||||
session.setLocalRepositoryManager(repository.newLocalRepositoryManager(session, new LocalRepository("libraries")));
|
session.setLocalRepositoryManager(repository.newLocalRepositoryManager(session, new LocalRepository("libraries")));
|
||||||
session.setTransferListener(new AbstractTransferListener() {
|
session.setTransferListener(new AbstractTransferListener()
|
||||||
|
{
|
||||||
@Override
|
@Override
|
||||||
public void transferStarted(@NotNull TransferEvent event) throws TransferCancelledException {
|
public void transferStarted(@NotNull TransferEvent event) throws TransferCancelledException
|
||||||
|
{
|
||||||
logger.log(Level.INFO, "Downloading {0}", event.getResource().getRepositoryUrl() + event.getResource().getResourceName());
|
logger.log(Level.INFO, "Downloading {0}", event.getResource().getRepositoryUrl() + event.getResource().getResourceName());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -76,8 +80,10 @@ public class LibraryLoader {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public ClassLoader createLoader(@NotNull PlexModule module, @NotNull PlexModuleFile moduleFile) {
|
public ClassLoader createLoader(@NotNull PlexModule module, @NotNull PlexModuleFile moduleFile)
|
||||||
if (moduleFile.getLibraries().isEmpty()) {
|
{
|
||||||
|
if (moduleFile.getLibraries().isEmpty())
|
||||||
|
{
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
logger.log(Level.INFO, "Loading libraries for {0}", new Object[]{moduleFile.getName()});
|
logger.log(Level.INFO, "Loading libraries for {0}", new Object[]{moduleFile.getName()});
|
||||||
@ -89,7 +95,8 @@ public class LibraryLoader {
|
|||||||
List<Dependency> dependencies = new ArrayList<>();
|
List<Dependency> dependencies = new ArrayList<>();
|
||||||
List<Class<?>> classes = Lists.newArrayList();
|
List<Class<?>> classes = Lists.newArrayList();
|
||||||
List<File> files = Lists.newArrayList();
|
List<File> files = Lists.newArrayList();
|
||||||
for (String library : moduleFile.getLibraries()) {
|
for (String library : moduleFile.getLibraries())
|
||||||
|
{
|
||||||
Artifact artifact = new DefaultArtifact(library);
|
Artifact artifact = new DefaultArtifact(library);
|
||||||
Dependency dependency = new Dependency(artifact, null);
|
Dependency dependency = new Dependency(artifact, null);
|
||||||
|
|
||||||
@ -97,20 +104,27 @@ public class LibraryLoader {
|
|||||||
}
|
}
|
||||||
|
|
||||||
DependencyResult result;
|
DependencyResult result;
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
result = repository.resolveDependencies(session, new DependencyRequest(new CollectRequest((Dependency)null, dependencies, repositories), null));
|
result = repository.resolveDependencies(session, new DependencyRequest(new CollectRequest((Dependency)null, dependencies, repositories), null));
|
||||||
} catch (DependencyResolutionException ex) {
|
}
|
||||||
|
catch (DependencyResolutionException ex)
|
||||||
|
{
|
||||||
throw new RuntimeException("Error resolving libraries", ex);
|
throw new RuntimeException("Error resolving libraries", ex);
|
||||||
}
|
}
|
||||||
|
|
||||||
List<URL> jarFiles = new ArrayList<>();
|
List<URL> jarFiles = new ArrayList<>();
|
||||||
for (ArtifactResult artifact : result.getArtifactResults()) {
|
for (ArtifactResult artifact : result.getArtifactResults())
|
||||||
|
{
|
||||||
File file = artifact.getArtifact().getFile();
|
File file = artifact.getArtifact().getFile();
|
||||||
files.add(file);
|
files.add(file);
|
||||||
URL url;
|
URL url;
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
url = file.toURI().toURL();
|
url = file.toURI().toURL();
|
||||||
} catch (MalformedURLException ex) {
|
}
|
||||||
|
catch (MalformedURLException ex)
|
||||||
|
{
|
||||||
throw new AssertionError(ex);
|
throw new AssertionError(ex);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,21 +181,29 @@ public class LibraryLoader {
|
|||||||
});
|
});
|
||||||
|
|
||||||
classes.forEach(clazz -> logger.log(Level.INFO, "Loading class {0}", new Object[]{clazz.getName()}));*/
|
classes.forEach(clazz -> logger.log(Level.INFO, "Loading class {0}", new Object[]{clazz.getName()}));*/
|
||||||
jarFiles.forEach(url -> {
|
jarFiles.forEach(url ->
|
||||||
|
{
|
||||||
JarURLConnection connection;
|
JarURLConnection connection;
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
URL url2 = new URL("jar:" + url.toString() + "!/");
|
URL url2 = new URL("jar:" + url.toString() + "!/");
|
||||||
/*
|
/*
|
||||||
connection = (JarURLConnection) url2.openConnection();
|
connection = (JarURLConnection) url2.openConnection();
|
||||||
logger.log(Level.INFO, "Jar File: " + connection.getJarFileURL().toString());*/
|
logger.log(Level.INFO, "Jar File: " + connection.getJarFileURL().toString());*/
|
||||||
} catch (IOException e) {
|
}
|
||||||
|
catch (IOException e)
|
||||||
|
{
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return new URLClassLoader(files.stream().map(File::toURI).map(uri -> {
|
return new URLClassLoader(files.stream().map(File::toURI).map(uri ->
|
||||||
try {
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
return uri.toURL();
|
return uri.toURL();
|
||||||
} catch (MalformedURLException e) {
|
}
|
||||||
|
catch (MalformedURLException e)
|
||||||
|
{
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -216,21 +238,27 @@ public class LibraryLoader {
|
|||||||
}*/
|
}*/
|
||||||
|
|
||||||
|
|
||||||
private ArrayList<String> getClassNamesFromJar(JarFile file) throws Exception {
|
private ArrayList<String> getClassNamesFromJar(JarFile file) throws Exception
|
||||||
|
{
|
||||||
ArrayList<String> classNames = new ArrayList<>();
|
ArrayList<String> classNames = new ArrayList<>();
|
||||||
try {
|
try
|
||||||
|
{
|
||||||
//Iterate through the contents of the jar file
|
//Iterate through the contents of the jar file
|
||||||
Enumeration<JarEntry> entries = file.entries();
|
Enumeration<JarEntry> entries = file.entries();
|
||||||
while (entries.hasMoreElements()) {
|
while (entries.hasMoreElements())
|
||||||
|
{
|
||||||
JarEntry entry = entries.nextElement();
|
JarEntry entry = entries.nextElement();
|
||||||
//Pick file that has the extension of .class
|
//Pick file that has the extension of .class
|
||||||
if ((entry.getName().endsWith(".class"))) {
|
if ((entry.getName().endsWith(".class")))
|
||||||
|
{
|
||||||
String className = entry.getName().replaceAll("/", "\\.");
|
String className = entry.getName().replaceAll("/", "\\.");
|
||||||
String myClass = className.substring(0, className.lastIndexOf('.'));
|
String myClass = className.substring(0, className.lastIndexOf('.'));
|
||||||
classNames.add(myClass);
|
classNames.add(myClass);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
throw new Exception("Error while getting class names from jar", e);
|
throw new Exception("Error while getting class names from jar", e);
|
||||||
}
|
}
|
||||||
return classNames;
|
return classNames;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user