Updated VaultExtension

- Fixed economy call when player has no economy account
- Adds support for permission groups

Affects issues:
- Fixed #1331
This commit is contained in:
Rsl1122 2020-02-14 15:02:54 +02:00
parent d2c72050dd
commit d3fd60a92e
2 changed files with 19 additions and 9 deletions

View File

@ -29,7 +29,7 @@ dependencies {
compile 'com.djrapitops:Extension-SuperbVote:0.5.4-R0.1' compile 'com.djrapitops:Extension-SuperbVote:0.5.4-R0.1'
compile 'com.djrapitops:Extension-Tebex:R0.3' compile 'com.djrapitops:Extension-Tebex:R0.3'
compile 'com.djrapitops:Extension-Towny:0.92.0.0-R0.1' compile 'com.djrapitops:Extension-Towny:0.92.0.0-R0.1'
compile 'com.djrapitops:Extension-Vault:1.7-R0.2' compile 'com.djrapitops:Extension-Vault:1.7-R0.3'
compile 'com.djrapitops:Extension-ViaVersion:2.1.3-R1.2' compile 'com.djrapitops:Extension-ViaVersion:2.1.3-R1.2'
} }

View File

@ -26,6 +26,7 @@ import com.djrapitops.plan.extension.extractor.ExtensionExtractor;
import javax.inject.Inject; import javax.inject.Inject;
import javax.inject.Named; import javax.inject.Named;
import javax.inject.Singleton; import javax.inject.Singleton;
import java.util.Collection;
import java.util.Optional; import java.util.Optional;
import java.util.Set; import java.util.Set;
import java.util.function.BiConsumer; import java.util.function.BiConsumer;
@ -76,7 +77,7 @@ public class ExtensionRegister {
register(new LitebansExtensionFactory(), LitebansExtensionFactory::createExtension, LitebansExtensionFactory::registerEvents); register(new LitebansExtensionFactory(), LitebansExtensionFactory::createExtension, LitebansExtensionFactory::registerEvents);
register(new LuckPermsExtensionFactory(), LuckPermsExtensionFactory::createExtension); register(new LuckPermsExtensionFactory(), LuckPermsExtensionFactory::createExtension);
register(new McMMOExtensionFactory(), McMMOExtensionFactory::createExtension); register(new McMMOExtensionFactory(), McMMOExtensionFactory::createExtension);
registerMinigameLibExtensions(); registerMany(new MinigameLibExtensionFactory(), MinigameLibExtensionFactory::createExtensions);
register(new NucleusExtensionFactory(), NucleusExtensionFactory::createExtension); register(new NucleusExtensionFactory(), NucleusExtensionFactory::createExtension);
register(new NuVotifierExtensionFactory(), NuVotifierExtensionFactory::createExtension); register(new NuVotifierExtensionFactory(), NuVotifierExtensionFactory::createExtension);
register(new ProtocolSupportExtensionFactory(), ProtocolSupportExtensionFactory::createExtension); register(new ProtocolSupportExtensionFactory(), ProtocolSupportExtensionFactory::createExtension);
@ -84,7 +85,7 @@ public class ExtensionRegister {
register(new SpongeEconomyExtensionFactory(), SpongeEconomyExtensionFactory::createExtension); register(new SpongeEconomyExtensionFactory(), SpongeEconomyExtensionFactory::createExtension);
register(new SuperbVoteExtensionFactory(), SuperbVoteExtensionFactory::createExtension); register(new SuperbVoteExtensionFactory(), SuperbVoteExtensionFactory::createExtension);
register(new TownyExtensionFactory(), TownyExtensionFactory::createExtension); register(new TownyExtensionFactory(), TownyExtensionFactory::createExtension);
register(new VaultExtensionFactory(), VaultExtensionFactory::createExtension); registerMany(new VaultExtensionFactory(), VaultExtensionFactory::createExtensions);
register(new ViaVersionExtensionFactory(), ViaVersionExtensionFactory::createExtension); register(new ViaVersionExtensionFactory(), ViaVersionExtensionFactory::createExtension);
if (registerException != null) throw registerException; if (registerException != null) throw registerException;
@ -99,12 +100,6 @@ public class ExtensionRegister {
} }
} }
private void registerMinigameLibExtensions() {
for (DataExtension minigame : new MinigameLibExtensionFactory().createExtensions()) {
register(minigame);
}
}
private void suppressException(Class<?> factory, Throwable e) { private void suppressException(Class<?> factory, Throwable e) {
String factoryName = factory.getSimpleName(); String factoryName = factory.getSimpleName();
String extensionName = factoryName.replace("ExtensionFactory", ""); String extensionName = factoryName.replace("ExtensionFactory", "");
@ -151,6 +146,21 @@ public class ExtensionRegister {
} }
} }
private <T> void registerMany(
T factory,
Function<T, Collection<DataExtension>> createExtension
) {
try {
// Creates the extension with factory and registers it
createExtension.apply(factory).forEach(this::register);
} catch (NotReadyException ignore) {
// This exception signals that the extension can not be registered right now (Intended fail).
} catch (Exception | NoClassDefFoundError | IncompatibleClassChangeError e) {
// Places all exceptions to one exception with plugin information so that they can be reported.
suppressException(factory.getClass(), e);
}
}
private <T> void register( private <T> void register(
T factory, T factory,
Function<T, Optional<DataExtension>> createExtension, Function<T, Optional<DataExtension>> createExtension,