2017-06-02 15:51:03 +02:00
|
|
|
package me.libraryaddict.disguise.utilities;
|
|
|
|
|
2019-01-03 03:13:03 +01:00
|
|
|
import me.libraryaddict.disguise.utilities.reflection.ReflectionManager;
|
2018-10-23 23:11:37 +02:00
|
|
|
import org.bukkit.configuration.file.YamlConfiguration;
|
|
|
|
|
2017-06-02 15:51:03 +02:00
|
|
|
import java.io.File;
|
|
|
|
import java.net.URL;
|
|
|
|
import java.net.URLClassLoader;
|
2019-02-16 04:57:07 +01:00
|
|
|
import java.text.ParseException;
|
|
|
|
import java.text.SimpleDateFormat;
|
|
|
|
import java.util.Date;
|
2017-06-02 15:51:03 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Created by libraryaddict on 2/06/2017.
|
|
|
|
*/
|
2017-06-08 17:09:28 +02:00
|
|
|
public class LibsPremium {
|
2019-02-16 04:57:07 +01:00
|
|
|
private static class PluginInformation {
|
|
|
|
private String userID;
|
|
|
|
private boolean premium;
|
|
|
|
private String version;
|
|
|
|
private String buildNumber;
|
|
|
|
private String buildDate;
|
|
|
|
|
|
|
|
public PluginInformation(String userID, boolean premium, String version, String buildNumber, String buildDate) {
|
|
|
|
this.userID = userID;
|
|
|
|
this.premium = premium;
|
|
|
|
this.version = version;
|
|
|
|
this.buildNumber = buildNumber;
|
|
|
|
this.buildDate = buildDate;
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getUserID() {
|
|
|
|
return userID;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isPremium() {
|
|
|
|
return premium;
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getVersion() {
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getBuildNumber() {
|
|
|
|
return buildNumber;
|
|
|
|
}
|
|
|
|
|
|
|
|
public String getBuildDate() {
|
|
|
|
return buildDate;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Date getParsedBuildDate() {
|
|
|
|
try {
|
|
|
|
return new SimpleDateFormat("dd/MM/yyyy HH:mm").parse(getBuildDate());
|
|
|
|
}
|
|
|
|
catch (ParseException e) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-02 15:51:03 +02:00
|
|
|
private static Boolean thisPluginIsPaidFor;
|
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
/**
|
|
|
|
* @return Account ID if downloaded through SpigotMC
|
|
|
|
*/
|
|
|
|
public static String getUserID() {
|
|
|
|
return "%%__USER__%%";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Resource ID if downloaded through SpigotMC
|
|
|
|
*/
|
|
|
|
public static String getResourceID() {
|
|
|
|
return "%%__RESOURCE__%%";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Download ID if downloaded through SpigotMC
|
|
|
|
*/
|
|
|
|
public static String getDownloadID() {
|
|
|
|
return "%%__NONCE__%%";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param userID
|
|
|
|
* @return true if userID does not contain __USER__
|
|
|
|
*/
|
|
|
|
private static Boolean isPremium(String userID) {
|
|
|
|
return !userID.contains("__USER__");
|
|
|
|
}
|
|
|
|
|
2017-06-02 15:51:03 +02:00
|
|
|
public static Boolean isPremium() {
|
2019-02-16 04:57:07 +01:00
|
|
|
return thisPluginIsPaidFor == null ? !getUserID().contains("__USER__") : thisPluginIsPaidFor;
|
2017-06-02 15:51:03 +02:00
|
|
|
}
|
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
private static PluginInformation getInformation(File file) throws Exception {
|
|
|
|
try (URLClassLoader cl = new URLClassLoader(new URL[]{file.toURI().toURL()})) {
|
|
|
|
Class c = cl.loadClass(LibsPremium.class.getName());
|
2017-06-02 15:51:03 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
boolean oldJarFile = true;
|
2017-06-08 17:06:58 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
try {
|
|
|
|
// Error thrown if method doesn't exist
|
|
|
|
c.getMethod("getUserID");
|
|
|
|
// Method exists, is not older file
|
|
|
|
oldJarFile = false;
|
|
|
|
}
|
|
|
|
catch (Exception ignored) {
|
|
|
|
}
|
2017-06-08 17:06:58 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
// Fetch the plugin.yml from the jar file
|
|
|
|
YamlConfiguration config = ReflectionManager.getPluginYaml(cl);
|
|
|
|
// No checks for null config as the correct error will be thrown on access
|
2017-06-02 15:51:03 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
Boolean premium;
|
|
|
|
String userId = null;
|
2017-06-02 15:51:03 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
if (oldJarFile) {
|
|
|
|
premium = (Boolean) c.getMethod("isPremium").invoke(null);
|
|
|
|
} else {
|
|
|
|
userId = (String) c.getMethod("getUserID").invoke(null);
|
|
|
|
premium = isPremium(userId);
|
|
|
|
}
|
2017-06-02 15:51:03 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
String pluginBuildDate = "??/??/????";
|
2018-10-23 23:11:37 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
// If plugin.yml contains a build-date
|
|
|
|
if (config.contains("build-date")) {
|
|
|
|
pluginBuildDate = config.getString("build-date");
|
|
|
|
}
|
2018-10-23 23:11:37 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
String pluginBuildNumber = "???";
|
2017-06-02 15:51:03 +02:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
// If plugin.yml contains a jenkins build number
|
|
|
|
if (config.contains("build-number")) {
|
|
|
|
pluginBuildNumber = config.getString("build-number");
|
2018-02-15 22:51:15 +01:00
|
|
|
|
2019-02-16 04:57:07 +01:00
|
|
|
// If build number is composed of purely numbers, prepend with # for readability
|
|
|
|
if (pluginBuildNumber.matches("[0-9]+")) {
|
|
|
|
pluginBuildNumber = "#" + pluginBuildNumber;
|
2017-06-02 15:51:03 +02:00
|
|
|
}
|
|
|
|
}
|
2019-02-16 04:57:07 +01:00
|
|
|
|
|
|
|
String pluginVersion = config.getString("version");
|
|
|
|
|
|
|
|
return new PluginInformation(userId, premium, pluginVersion, pluginBuildNumber, pluginBuildDate);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void doSecondaryCheck() {
|
|
|
|
File[] files = new File("plugins/LibsDisguises/").listFiles();
|
|
|
|
|
|
|
|
if (files == null)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (File file : files) {
|
|
|
|
if (!file.isFile())
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if (!file.getName().endsWith(".jar"))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
PluginInformation plugin;
|
|
|
|
|
|
|
|
try {
|
|
|
|
plugin = getInformation(file);
|
|
|
|
}
|
|
|
|
catch (ClassNotFoundException ex) {
|
|
|
|
DisguiseUtilities.getLogger()
|
|
|
|
.warning("Found an unrecognized jar in the LibsDisguises folder (" + file.getName() + ")");
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
catch (Exception ex) {
|
|
|
|
DisguiseUtilities.getLogger().warning("Error while trying to handle the file " + file.getName());
|
|
|
|
ex.printStackTrace();
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Format into a string
|
|
|
|
// v5.2.6, build #40, created 16/02/2019
|
|
|
|
String fileInfo = String.format("v%s, build %s, created %s", plugin.getVersion(), plugin.getBuildNumber(),
|
|
|
|
plugin.getBuildDate());
|
|
|
|
|
|
|
|
if (plugin.isPremium()) {
|
|
|
|
thisPluginIsPaidFor = true;
|
|
|
|
// Found a premium Lib's Disguises jar (v5.2.6, build #40, created 16/02/2019)
|
|
|
|
DisguiseUtilities.getLogger()
|
|
|
|
.info("Found a premium Lib's Disguises jar (" + fileInfo + ")");
|
|
|
|
|
|
|
|
break;
|
|
|
|
} else {
|
|
|
|
// You have a non-premium Lib's Disguises jar (LibsDisguises.jar v5.2.6, build #40, created
|
|
|
|
// 16/02/2019) in the LibsDisguises folder!
|
|
|
|
DisguiseUtilities.getLogger().warning(
|
|
|
|
"You have a non-premium Lib's Disguises jar (" + file.getName() + " " + fileInfo +
|
|
|
|
") in the LibsDisguises folder!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void check(String version) {
|
|
|
|
thisPluginIsPaidFor = isPremium();
|
|
|
|
|
|
|
|
if (!isPremium()) {
|
|
|
|
doSecondaryCheck();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isPremium()) {
|
|
|
|
DisguiseUtilities.getLogger().info("Premium enabled, thank you for supporting Lib's Disguises!");
|
2017-06-02 15:51:03 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|