2013-03-01 06:52:01 +01:00
|
|
|
package com.gmail.nossr50.metrics;
|
2013-02-15 17:11:47 +01:00
|
|
|
|
|
|
|
import java.io.BufferedReader;
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.io.InputStreamReader;
|
|
|
|
import java.util.Locale;
|
|
|
|
|
|
|
|
import com.gmail.nossr50.mcMMO;
|
|
|
|
import com.gmail.nossr50.config.Config;
|
|
|
|
import com.gmail.nossr50.config.HiddenConfig;
|
|
|
|
import com.gmail.nossr50.locale.LocaleLoader;
|
2013-02-16 02:48:14 +01:00
|
|
|
import com.turt2live.metrics.EMetrics;
|
2013-02-15 17:11:47 +01:00
|
|
|
import com.turt2live.metrics.Metrics;
|
|
|
|
import com.turt2live.metrics.Metrics.Graph;
|
2013-03-01 06:52:01 +01:00
|
|
|
import com.turt2live.metrics.data.DataEvent;
|
|
|
|
import com.turt2live.metrics.data.DataTracker;
|
2013-02-16 02:59:38 +01:00
|
|
|
import com.turt2live.metrics.tracker.Tracker;
|
2013-02-15 17:11:47 +01:00
|
|
|
|
|
|
|
public class MetricsManager {
|
|
|
|
private static boolean setup = false;
|
|
|
|
|
2013-02-16 02:59:38 +01:00
|
|
|
private static Tracker chimeraUseTracker;
|
|
|
|
private static Tracker chimeraServerUseTracker;
|
|
|
|
|
2013-02-22 07:08:37 +01:00
|
|
|
private static boolean customConfig = false;
|
|
|
|
|
2013-02-16 03:46:52 +01:00
|
|
|
private static DataTracker tracker;
|
|
|
|
private static EMetrics emetrics;
|
|
|
|
|
2013-02-15 17:11:47 +01:00
|
|
|
public static void setup() {
|
|
|
|
if (setup) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Config.getInstance().getStatsTrackingEnabled()) {
|
|
|
|
try {
|
2013-02-16 03:46:52 +01:00
|
|
|
emetrics = new EMetrics(mcMMO.p);
|
2013-02-16 02:48:14 +01:00
|
|
|
Metrics metrics = emetrics.getMetrics();
|
2013-02-15 17:11:47 +01:00
|
|
|
|
|
|
|
// Timings Graph
|
|
|
|
Graph timingsGraph = metrics.createGraph("Percentage of servers using timings");
|
|
|
|
|
|
|
|
if (mcMMO.p.getServer().getPluginManager().useTimings()) {
|
|
|
|
timingsGraph.addPlotter(new Metrics.Plotter("Enabled") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
timingsGraph.addPlotter(new Metrics.Plotter("Disabled") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Donut Version Graph
|
|
|
|
Graph versionDonutGraph = metrics.createGraph("Donut Version");
|
|
|
|
|
|
|
|
boolean haveVersionInformation = false;
|
|
|
|
boolean isOfficialBuild = false;
|
|
|
|
String officialKey = "e14cfacdd442a953343ebd8529138680";
|
|
|
|
|
|
|
|
String version = mcMMO.p.getDescription().getVersion();
|
|
|
|
|
|
|
|
InputStreamReader isr = new InputStreamReader(mcMMO.p.getResource(".jenkins"));
|
|
|
|
BufferedReader br = new BufferedReader(isr);
|
|
|
|
char[] key = new char[32];
|
|
|
|
br.read(key);
|
|
|
|
if (officialKey.equals(String.valueOf(key))) {
|
|
|
|
isOfficialBuild = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (version.contains("-")) {
|
|
|
|
String majorVersion = version.substring(0, version.indexOf("-"));
|
|
|
|
String subVersion = "";
|
|
|
|
if (isOfficialBuild) {
|
|
|
|
int startIndex = version.indexOf("-");
|
|
|
|
if (version.substring(startIndex + 1).contains("-")) {
|
|
|
|
subVersion = version.substring(startIndex, version.indexOf("-", startIndex + 1));
|
2013-03-01 06:52:01 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-02-15 17:11:47 +01:00
|
|
|
subVersion = "-release";
|
|
|
|
}
|
2013-03-01 06:52:01 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-02-15 17:11:47 +01:00
|
|
|
subVersion = "-custom";
|
|
|
|
}
|
|
|
|
|
|
|
|
version = majorVersion + "~=~" + subVersion;
|
|
|
|
haveVersionInformation = true;
|
2013-03-01 06:52:01 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-02-15 17:11:47 +01:00
|
|
|
haveVersionInformation = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (haveVersionInformation) {
|
|
|
|
versionDonutGraph.addPlotter(new Metrics.Plotter(version) {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Official v Custom build Graph
|
|
|
|
Graph officialGraph = metrics.createGraph("Built by official ci");
|
|
|
|
|
|
|
|
if (isOfficialBuild) {
|
|
|
|
officialGraph.addPlotter(new Metrics.Plotter("Yes") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
officialGraph.addPlotter(new Metrics.Plotter("No") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Chunkmeta enabled Graph
|
|
|
|
Graph chunkmetaGraph = metrics.createGraph("Uses Chunkmeta");
|
|
|
|
|
|
|
|
if (HiddenConfig.getInstance().getChunkletsEnabled()) {
|
|
|
|
chunkmetaGraph.addPlotter(new Metrics.Plotter("Yes") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
chunkmetaGraph.addPlotter(new Metrics.Plotter("No") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Storage method Graph
|
|
|
|
Graph storageGraph = metrics.createGraph("Storage method");
|
|
|
|
|
|
|
|
if (Config.getInstance().getUseMySQL()) {
|
|
|
|
storageGraph.addPlotter(new Metrics.Plotter("SQL") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
storageGraph.addPlotter(new Metrics.Plotter("Flatfile") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Locale Graph
|
|
|
|
Graph localeGraph = metrics.createGraph("Locale");
|
|
|
|
|
|
|
|
localeGraph.addPlotter(new Metrics.Plotter(LocaleLoader.getCurrentLocale().getDisplayLanguage(Locale.US)) {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// GlobalMultiplier Graph
|
|
|
|
Graph globalMultiplierGraph = metrics.createGraph("Global Multiplier Graph");
|
|
|
|
|
|
|
|
globalMultiplierGraph.addPlotter(new Metrics.Plotter(Config.getInstance().getExperienceGainsGlobalMultiplier() + "") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// GlobalCurveModifier Graph
|
|
|
|
Graph globalCurveModifierGraph = metrics.createGraph("Global Curve Modifier Graph");
|
|
|
|
|
|
|
|
globalCurveModifierGraph.addPlotter(new Metrics.Plotter(Config.getInstance().getFormulaMultiplierCurve() + "") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-02-23 05:54:15 +01:00
|
|
|
// GlobalMultiplierGraph Fuzzy Logic Numbers
|
|
|
|
Graph globalMultiplierGraphFuzzy = metrics.createGraph("Global Multiplier Fuzz");
|
|
|
|
|
|
|
|
if (Config.getInstance().getExperienceGainsGlobalMultiplier() > 1.0) {
|
2013-02-23 06:00:58 +01:00
|
|
|
globalMultiplierGraphFuzzy.addPlotter(new Metrics.Plotter("Higher") {
|
2013-02-23 05:54:15 +01:00
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else if (Config.getInstance().getExperienceGainsGlobalMultiplier() < 1.0) {
|
2013-02-23 06:00:58 +01:00
|
|
|
globalMultiplierGraphFuzzy.addPlotter(new Metrics.Plotter("Lower") {
|
2013-02-23 05:54:15 +01:00
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
2013-02-23 06:00:58 +01:00
|
|
|
globalMultiplierGraphFuzzy.addPlotter(new Metrics.Plotter("Default") {
|
2013-02-23 05:54:15 +01:00
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2013-03-01 06:52:01 +01:00
|
|
|
// GlobalCurveModifier Fuzzy Logic Numbers
|
2013-02-23 05:54:15 +01:00
|
|
|
Graph globalCurveMultiplierGraphFuzzy = metrics.createGraph("Global Curve Multiplier Fuzz");
|
|
|
|
|
|
|
|
if (Config.getInstance().getFormulaMultiplierCurve() > 20.0) {
|
2013-02-23 06:00:58 +01:00
|
|
|
globalCurveMultiplierGraphFuzzy.addPlotter(new Metrics.Plotter("Higher") {
|
2013-02-23 05:54:15 +01:00
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else if (Config.getInstance().getFormulaMultiplierCurve() < 20.0) {
|
2013-02-23 06:00:58 +01:00
|
|
|
globalCurveMultiplierGraphFuzzy.addPlotter(new Metrics.Plotter("Lower") {
|
2013-02-23 05:54:15 +01:00
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
2013-02-23 06:00:58 +01:00
|
|
|
globalCurveMultiplierGraphFuzzy.addPlotter(new Metrics.Plotter("Default") {
|
2013-02-23 05:54:15 +01:00
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2013-02-16 02:59:38 +01:00
|
|
|
// Chimera Wing Usage Trackers
|
|
|
|
final String chimeraGraphName = "Chimera Wing Usage";
|
|
|
|
|
|
|
|
chimeraUseTracker = EMetrics.createBasicTracker(chimeraGraphName, "Player use");
|
|
|
|
chimeraServerUseTracker = EMetrics.createEnabledTracker(chimeraGraphName, "Server use");
|
|
|
|
|
|
|
|
emetrics.addTracker(chimeraUseTracker);
|
|
|
|
emetrics.addTracker(chimeraServerUseTracker);
|
|
|
|
|
2013-02-16 02:48:52 +01:00
|
|
|
// Chimera Wing Enabled Graph
|
|
|
|
Graph chimeraGraph = metrics.createGraph("Chimera Wing");
|
|
|
|
|
|
|
|
if (Config.getInstance().getChimaeraEnabled()) {
|
|
|
|
chimeraGraph.addPlotter(new Metrics.Plotter("Enabled") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
chimeraGraph.addPlotter(new Metrics.Plotter("Disabled") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2013-02-22 07:08:37 +01:00
|
|
|
// Vanilla v Modified config graph
|
|
|
|
Graph customConfigGraph = metrics.createGraph("Modified Configs");
|
|
|
|
|
|
|
|
if (customConfig) {
|
|
|
|
customConfigGraph.addPlotter(new Metrics.Plotter("Edited") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
customConfigGraph.addPlotter(new Metrics.Plotter("Vanilla") {
|
|
|
|
@Override
|
|
|
|
public int getValue() {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2013-03-01 06:52:01 +01:00
|
|
|
/*
|
|
|
|
* Debug stuff
|
|
|
|
* tracker = emetrics.getDataTracker();
|
|
|
|
* tracker.enable();
|
|
|
|
* tracker.setFilter(new DataEvent.DataType [] { DataEvent.DataType.SEND_DATA });
|
|
|
|
*/
|
2013-02-16 03:46:52 +01:00
|
|
|
|
2013-02-16 02:48:14 +01:00
|
|
|
emetrics.startMetrics();
|
2013-02-15 17:11:47 +01:00
|
|
|
}
|
|
|
|
catch (IOException e) {
|
|
|
|
mcMMO.p.getLogger().warning("Failed to submit stats.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-02-16 02:59:38 +01:00
|
|
|
|
|
|
|
public static void chimeraWingUsed() {
|
2013-02-16 03:33:17 +01:00
|
|
|
chimeraUseTracker.increment();
|
|
|
|
chimeraServerUseTracker.increment();
|
2013-02-16 03:46:52 +01:00
|
|
|
}
|
|
|
|
|
2013-02-22 07:08:37 +01:00
|
|
|
public static void customConfig() {
|
|
|
|
customConfig = true;
|
|
|
|
}
|
|
|
|
|
2013-02-16 04:45:04 +01:00
|
|
|
@SuppressWarnings("unused")
|
2013-02-16 03:46:52 +01:00
|
|
|
private static void debug() {
|
|
|
|
emetrics.getMetrics().flush();
|
|
|
|
|
|
|
|
for (DataEvent event : tracker.getEvents()) {
|
|
|
|
String graphName = event.getGraphName();
|
|
|
|
String colName = event.getTrackerName();
|
|
|
|
int value = event.getValueSent();
|
|
|
|
|
|
|
|
System.out.println("Graph: " + graphName + ", Column: " + colName + ", Value: " + value);
|
|
|
|
}
|
2013-02-16 04:06:16 +01:00
|
|
|
|
|
|
|
tracker.resetEvents();
|
2013-02-16 02:59:38 +01:00
|
|
|
}
|
2013-02-15 17:11:47 +01:00
|
|
|
}
|