mirror of
https://github.com/ChestShop-authors/ChestShop-3.git
synced 2025-01-18 21:01:33 +01:00
Fix Vault No Economy Plugin Found Error (#613)
This commit is contained in:
parent
1e40caa64a
commit
c5fc9f76fe
@ -14,6 +14,7 @@ import com.Acrobot.ChestShop.Listeners.Block.BlockPlace;
|
|||||||
import com.Acrobot.ChestShop.Listeners.Block.Break.ChestBreak;
|
import com.Acrobot.ChestShop.Listeners.Block.Break.ChestBreak;
|
||||||
import com.Acrobot.ChestShop.Listeners.Block.Break.SignBreak;
|
import com.Acrobot.ChestShop.Listeners.Block.Break.SignBreak;
|
||||||
import com.Acrobot.ChestShop.Listeners.Block.SignCreate;
|
import com.Acrobot.ChestShop.Listeners.Block.SignCreate;
|
||||||
|
import com.Acrobot.ChestShop.Listeners.Economy.EconomyAdapter;
|
||||||
import com.Acrobot.ChestShop.Listeners.Economy.ServerAccountCorrector;
|
import com.Acrobot.ChestShop.Listeners.Economy.ServerAccountCorrector;
|
||||||
import com.Acrobot.ChestShop.Listeners.Economy.TaxModule;
|
import com.Acrobot.ChestShop.Listeners.Economy.TaxModule;
|
||||||
import com.Acrobot.ChestShop.Listeners.AuthMeChestShopListener;
|
import com.Acrobot.ChestShop.Listeners.AuthMeChestShopListener;
|
||||||
@ -92,6 +93,7 @@ import java.util.List;
|
|||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.ExecutorService;
|
import java.util.concurrent.ExecutorService;
|
||||||
import java.util.concurrent.Executors;
|
import java.util.concurrent.Executors;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
@ -536,6 +538,16 @@ public class ChestShop extends JavaPlugin {
|
|||||||
return new DrilldownPie(statId, () -> map);
|
return new DrilldownPie(statId, () -> map);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static DrilldownPie createStaticDrilldownStat(String statId, Callable<EconomyAdapter.ProviderInfo> callableProviderInfo) {
|
||||||
|
return new DrilldownPie(statId, () -> {
|
||||||
|
EconomyAdapter.ProviderInfo providerInfo = callableProviderInfo.call();
|
||||||
|
if (providerInfo == null) {
|
||||||
|
return ImmutableMap.of();
|
||||||
|
}
|
||||||
|
return ImmutableMap.of(providerInfo.getName(), ImmutableMap.of(providerInfo.getVersion(), 1));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
private int[] getChartArray(boolean value) {
|
private int[] getChartArray(boolean value) {
|
||||||
return new int[]{!value ? 1 : 0, value ? 0 : 1};
|
return new int[]{!value ? 1 : 0, value ? 0 : 1};
|
||||||
}
|
}
|
||||||
|
@ -111,7 +111,7 @@ public class Dependencies implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ChestShop.getMetrics().addCustomChart(ChestShop.createStaticDrilldownStat("economyAdapter", plugin, Bukkit.getPluginManager().getPlugin(plugin).getDescription().getVersion()));
|
ChestShop.getMetrics().addCustomChart(ChestShop.createStaticDrilldownStat("economyAdapter", plugin, Bukkit.getPluginManager().getPlugin(plugin).getDescription().getVersion()));
|
||||||
ChestShop.getMetrics().addCustomChart(ChestShop.createStaticDrilldownStat("economyPlugin", economy.getProviderInfo().getName(), economy.getProviderInfo().getVersion()));
|
ChestShop.getMetrics().addCustomChart(ChestShop.createStaticDrilldownStat("economyPlugin", economy::getProviderInfo));
|
||||||
|
|
||||||
ChestShop.registerListener(economy);
|
ChestShop.registerListener(economy);
|
||||||
ChestShop.getBukkitLogger().info(plugin + " loaded!");
|
ChestShop.getBukkitLogger().info(plugin + " loaded!");
|
||||||
|
@ -11,11 +11,13 @@ import com.Acrobot.ChestShop.Events.Economy.CurrencySubtractEvent;
|
|||||||
import com.Acrobot.ChestShop.Events.Economy.CurrencyTransferEvent;
|
import com.Acrobot.ChestShop.Events.Economy.CurrencyTransferEvent;
|
||||||
import com.Acrobot.ChestShop.UUIDs.NameManager;
|
import com.Acrobot.ChestShop.UUIDs.NameManager;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
public abstract class EconomyAdapter implements Listener {
|
public abstract class EconomyAdapter implements Listener {
|
||||||
|
|
||||||
|
@Nullable
|
||||||
public abstract ProviderInfo getProviderInfo();
|
public abstract ProviderInfo getProviderInfo();
|
||||||
|
|
||||||
public abstract void onAmountCheck(CurrencyAmountEvent event);
|
public abstract void onAmountCheck(CurrencyAmountEvent event);
|
||||||
|
@ -33,7 +33,10 @@ public class ReserveListener extends EconomyAdapter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ProviderInfo getProviderInfo() {
|
public @Nullable ProviderInfo getProviderInfo() {
|
||||||
|
if (economyAPI == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
return new ProviderInfo(economyAPI.name(), economyAPI.version());
|
return new ProviderInfo(economyAPI.name(), economyAPI.version());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,6 +15,7 @@ import org.bukkit.ChatColor;
|
|||||||
import org.bukkit.OfflinePlayer;
|
import org.bukkit.OfflinePlayer;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.server.ServerLoadEvent;
|
||||||
import org.bukkit.event.server.ServiceRegisterEvent;
|
import org.bukkit.event.server.ServiceRegisterEvent;
|
||||||
import org.bukkit.event.server.ServiceUnregisterEvent;
|
import org.bukkit.event.server.ServiceUnregisterEvent;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
@ -64,7 +65,10 @@ public class VaultListener extends EconomyAdapter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ProviderInfo getProviderInfo() {
|
public @Nullable ProviderInfo getProviderInfo() {
|
||||||
|
if (provider == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
return new ProviderInfo(provider.getName(), providingPlugin.getDescription().getVersion());
|
return new ProviderInfo(provider.getName(), providingPlugin.getDescription().getVersion());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -107,6 +111,17 @@ public class VaultListener extends EconomyAdapter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onServerLoad(ServerLoadEvent event) {
|
||||||
|
if (event.getType() == ServerLoadEvent.LoadType.STARTUP) {
|
||||||
|
// Server and plugins are loaded, so we can check for the economy provider now
|
||||||
|
if (provider == null) {
|
||||||
|
ChestShop.getBukkitLogger().log(Level.SEVERE, "No Vault compatible Economy plugin found!");
|
||||||
|
ChestShop.getBukkitServer().getPluginManager().disablePlugin(ChestShop.getPlugin());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void onAmountCheck(CurrencyAmountEvent event) {
|
public void onAmountCheck(CurrencyAmountEvent event) {
|
||||||
if (!checkSetup() || event.wasHandled() || !event.getAmount().equals(BigDecimal.ZERO)) {
|
if (!checkSetup() || event.wasHandled() || !event.getAmount().equals(BigDecimal.ZERO)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user