|
@@ -1,8 +1,15 @@
|
|
package de.Linus122.customoregen;
|
|
package de.Linus122.customoregen;
|
|
|
|
|
|
|
|
+import java.io.BufferedReader;
|
|
import java.io.DataOutputStream;
|
|
import java.io.DataOutputStream;
|
|
-import java.net.HttpURLConnection;
|
|
|
|
|
|
+import java.io.File;
|
|
|
|
+import java.io.FileReader;
|
|
|
|
+import java.io.FilenameFilter;
|
|
|
|
+import java.io.IOException;
|
|
|
|
+import java.nio.file.Files;
|
|
|
|
+import java.util.Arrays;
|
|
import java.util.HashMap;
|
|
import java.util.HashMap;
|
|
|
|
+import java.util.List;
|
|
|
|
|
|
import javax.net.ssl.HttpsURLConnection;
|
|
import javax.net.ssl.HttpsURLConnection;
|
|
|
|
|
|
@@ -10,6 +17,11 @@ import org.bukkit.plugin.Plugin;
|
|
|
|
|
|
import com.google.gson.Gson;
|
|
import com.google.gson.Gson;
|
|
|
|
|
|
|
|
+/*
|
|
|
|
+ * SpaceIOMetrics main class by Linus122
|
|
|
|
+ * version: 0.02
|
|
|
|
+ *
|
|
|
|
+ */
|
|
public class Metrics {
|
|
public class Metrics {
|
|
private Plugin pl;
|
|
private Plugin pl;
|
|
private final Gson gson = new Gson();
|
|
private final Gson gson = new Gson();
|
|
@@ -18,6 +30,18 @@ public class Metrics {
|
|
|
|
|
|
public Metrics(Plugin pl){
|
|
public Metrics(Plugin pl){
|
|
this.pl = pl;
|
|
this.pl = pl;
|
|
|
|
+
|
|
|
|
+ // check if Metrics are disabled (checks if file "disablemetrics" is added to the plugins's folder
|
|
|
|
+ try {
|
|
|
|
+ Files.list(pl.getDataFolder().getParentFile().toPath()).filter(Files::isRegularFile).forEach(v -> {
|
|
|
|
+ if(v.getFileName().toString().equalsIgnoreCase("disablemetrics")){
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ } catch (IOException e1) {
|
|
|
|
+ e1.printStackTrace();
|
|
|
|
+ }
|
|
|
|
+
|
|
URL = String.format(URL, pl.getName());
|
|
URL = String.format(URL, pl.getName());
|
|
pl.getServer().getScheduler().runTaskTimerAsynchronously(pl, () -> {
|
|
pl.getServer().getScheduler().runTaskTimerAsynchronously(pl, () -> {
|
|
String dataJson = collectData();
|
|
String dataJson = collectData();
|
|
@@ -41,6 +65,12 @@ public class Metrics {
|
|
// server version
|
|
// server version
|
|
data.serverVersion = getVersion();
|
|
data.serverVersion = getVersion();
|
|
|
|
|
|
|
|
+ // plugin version
|
|
|
|
+ data.pluginVersion = pl.getDescription().getVersion();
|
|
|
|
+
|
|
|
|
+ // plugin author
|
|
|
|
+ data.pluginAuthors = pl.getDescription().getAuthors();
|
|
|
|
+
|
|
// core count
|
|
// core count
|
|
data.coreCnt = Runtime.getRuntime().availableProcessors();
|
|
data.coreCnt = Runtime.getRuntime().availableProcessors();
|
|
|
|
|
|
@@ -50,6 +80,17 @@ public class Metrics {
|
|
// online mode
|
|
// online mode
|
|
data.onlineMode = pl.getServer().getOnlineMode();
|
|
data.onlineMode = pl.getServer().getOnlineMode();
|
|
|
|
|
|
|
|
+ // software information
|
|
|
|
+ data.osName = System.getProperty("os.name");
|
|
|
|
+ data.osArch = System.getProperty("os.arch");
|
|
|
|
+ data.osVersion = System.getProperty("os.version");
|
|
|
|
+
|
|
|
|
+ data.diskSize = new File("/").getTotalSpace();
|
|
|
|
+
|
|
|
|
+ if(data.osName.equals("Linux")){
|
|
|
|
+ data.linuxDistro = getDistro();
|
|
|
|
+ }
|
|
|
|
+
|
|
return gson.toJson(data);
|
|
return gson.toJson(data);
|
|
}
|
|
}
|
|
private void sendData(String dataJson) throws Exception{
|
|
private void sendData(String dataJson) throws Exception{
|
|
@@ -70,13 +111,55 @@ public class Metrics {
|
|
String packageName = pl.getServer().getClass().getPackage().getName();
|
|
String packageName = pl.getServer().getClass().getPackage().getName();
|
|
return packageName.substring(packageName.lastIndexOf('.') + 1);
|
|
return packageName.substring(packageName.lastIndexOf('.') + 1);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+ // method source: http://www.jcgonzalez.com/linux-get-distro-from-java-examples
|
|
|
|
+ private String getDistro(){
|
|
|
|
+ //lists all the files ending with -release in the etc folder
|
|
|
|
+ File dir = new File("/etc/");
|
|
|
|
+ File fileList[] = new File[0];
|
|
|
|
+ if(dir.exists()){
|
|
|
|
+ fileList = dir.listFiles(new FilenameFilter() {
|
|
|
|
+ public boolean accept(File dir, String filename) {
|
|
|
|
+ return filename.endsWith("-release");
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ }
|
|
|
|
+ //looks for the version file (not all linux distros)
|
|
|
|
+ File fileVersion = new File("/proc/version");
|
|
|
|
+ if(fileVersion.exists()){
|
|
|
|
+ fileList = Arrays.copyOf(fileList,fileList.length+1);
|
|
|
|
+ fileList[fileList.length-1] = fileVersion;
|
|
|
|
+ }
|
|
|
|
+ //prints first version-related file
|
|
|
|
+ for (File f : fileList) {
|
|
|
|
+ try {
|
|
|
|
+ BufferedReader myReader = new BufferedReader(new FileReader(f));
|
|
|
|
+ String strLine = null;
|
|
|
|
+ while ((strLine = myReader.readLine()) != null) {
|
|
|
|
+ return strLine;
|
|
|
|
+ }
|
|
|
|
+ myReader.close();
|
|
|
|
+ } catch (Exception e) {
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return "unknown";
|
|
|
|
+ }
|
|
}
|
|
}
|
|
class Data {
|
|
class Data {
|
|
HashMap<String, String> plugs = new HashMap<String, String>();
|
|
HashMap<String, String> plugs = new HashMap<String, String>();
|
|
int onlinePlayers;
|
|
int onlinePlayers;
|
|
|
|
+ String pluginVersion;
|
|
|
|
+ public List<String> pluginAuthors;
|
|
String serverVersion;
|
|
String serverVersion;
|
|
|
|
+
|
|
|
|
+ long diskSize;
|
|
int coreCnt;
|
|
int coreCnt;
|
|
String javaRuntime;
|
|
String javaRuntime;
|
|
|
|
+
|
|
boolean onlineMode;
|
|
boolean onlineMode;
|
|
-}
|
|
|
|
|
|
+
|
|
|
|
+ String osName;
|
|
|
|
+ String osArch;
|
|
|
|
+ String osVersion;
|
|
|
|
+ String linuxDistro;
|
|
|
|
+}
|