2011-09-21 09:29:21 -04:00
|
|
|
|
|
|
|
package net.sourceforge.filebot;
|
|
|
|
|
|
|
|
|
|
|
|
import static com.dmurph.tracking.JGoogleAnalyticsTracker.GoogleAnalyticsVersion.*;
|
|
|
|
import static net.sourceforge.filebot.Settings.*;
|
|
|
|
|
|
|
|
import java.awt.DisplayMode;
|
|
|
|
import java.awt.GraphicsDevice;
|
|
|
|
import java.awt.GraphicsEnvironment;
|
|
|
|
import java.awt.HeadlessException;
|
|
|
|
import java.util.Map;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
|
|
|
|
import com.dmurph.tracking.AnalyticsConfigData;
|
|
|
|
import com.dmurph.tracking.JGoogleAnalyticsTracker;
|
|
|
|
import com.dmurph.tracking.VisitorData;
|
|
|
|
import com.sun.jna.Platform;
|
|
|
|
|
|
|
|
|
|
|
|
public class Analytics {
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
private static JGoogleAnalyticsTracker tracker;
|
|
|
|
private static VisitorData visitorData;
|
2011-09-21 09:29:21 -04:00
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
private static String host = "filebot.sourceforge.net";
|
2011-10-30 06:36:40 -04:00
|
|
|
private static String currentView = null;
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
private static boolean enabled = false;
|
|
|
|
|
|
|
|
|
|
|
|
public static synchronized JGoogleAnalyticsTracker getTracker() {
|
|
|
|
if (tracker != null)
|
|
|
|
return tracker;
|
|
|
|
|
|
|
|
// initialize tracker
|
|
|
|
visitorData = restoreVisitorData();
|
|
|
|
tracker = new JGoogleAnalyticsTracker(getConfig(getApplicationProperty("analytics.WebPropertyID"), visitorData), V_4_7_2);
|
|
|
|
|
|
|
|
// store session data on shutdown
|
|
|
|
Runtime.getRuntime().addShutdownHook(new Thread("AnalyticsShutdownHook") {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
storeVisitorData(visitorData);
|
|
|
|
JGoogleAnalyticsTracker.completeBackgroundTasks(2000);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return tracker;
|
|
|
|
}
|
|
|
|
|
2011-09-21 09:29:21 -04:00
|
|
|
|
|
|
|
public static void trackView(Class<?> view, String title) {
|
2011-09-23 01:12:59 -04:00
|
|
|
trackView(view.getName().replace('.', '/'), title);
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static synchronized void trackView(String view, String title) {
|
2011-11-13 01:49:34 -05:00
|
|
|
if (!enabled)
|
2011-09-21 09:29:21 -04:00
|
|
|
return;
|
|
|
|
|
2011-10-30 06:36:40 -04:00
|
|
|
if (currentView == null) {
|
|
|
|
// track application startup
|
2011-11-13 01:49:34 -05:00
|
|
|
getTracker().trackPageViewFromSearch(view, title, host, getJavaVersionIdentifier(), getDeploymentMethod());
|
2011-10-30 06:36:40 -04:00
|
|
|
} else {
|
|
|
|
// track application state change
|
2011-11-13 01:49:34 -05:00
|
|
|
getTracker().trackPageViewFromReferrer(view, title, host, host, currentView);
|
2011-10-30 06:36:40 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
currentView = view;
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static void trackEvent(String category, String action, String label) {
|
|
|
|
trackEvent(category, action, label, null);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static synchronized void trackEvent(String category, String action, String label, Integer value) {
|
2011-11-13 01:49:34 -05:00
|
|
|
if (!enabled)
|
2011-09-21 09:29:21 -04:00
|
|
|
return;
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
getTracker().trackEvent(normalize(category), normalize(action), normalize(label), value);
|
2011-10-15 08:40:35 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String normalize(String label) {
|
|
|
|
if (label == null)
|
|
|
|
return null;
|
|
|
|
|
|
|
|
// trim braces
|
|
|
|
return label.replaceAll("[*()]", "").trim();
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
public static synchronized void setEnabled(boolean b) {
|
|
|
|
enabled = b;
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String getDeploymentMethod() {
|
|
|
|
return getApplicationDeployment() == null ? "fatjar" : getApplicationDeployment();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String getJavaVersionIdentifier() {
|
|
|
|
return System.getProperty("java.runtime.name") + " " + System.getProperty("java.version");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static AnalyticsConfigData getConfig(String webPropertyID, VisitorData visitorData) {
|
|
|
|
AnalyticsConfigData config = new AnalyticsConfigData(webPropertyID, visitorData);
|
|
|
|
|
|
|
|
config.setUserAgent(getUserAgent());
|
|
|
|
config.setEncoding(System.getProperty("file.encoding"));
|
|
|
|
config.setUserLanguage(getUserLanguage());
|
|
|
|
|
|
|
|
try {
|
|
|
|
GraphicsDevice[] display = GraphicsEnvironment.getLocalGraphicsEnvironment().getScreenDevices();
|
|
|
|
config.setScreenResolution(getScreenResolution(display));
|
|
|
|
config.setColorDepth(getColorDepth(display));
|
2011-11-28 04:18:51 -05:00
|
|
|
} catch (Throwable e) {
|
2011-10-14 05:51:45 -04:00
|
|
|
Logger.getLogger(Analytics.class.getName()).finest("Headless: " + e.getMessage());
|
2011-09-21 09:29:21 -04:00
|
|
|
config.setScreenResolution("80x25");
|
|
|
|
config.setColorDepth("1");
|
|
|
|
}
|
|
|
|
|
|
|
|
return config;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String getUserAgent() {
|
|
|
|
String wm = null;
|
|
|
|
String os = null;
|
|
|
|
|
|
|
|
if (Platform.isWindows()) {
|
|
|
|
wm = "Windows";
|
|
|
|
os = "Windows NT " + System.getProperty("os.version");
|
|
|
|
} else if (Platform.isX11()) {
|
|
|
|
wm = "X11";
|
|
|
|
if (Platform.isLinux())
|
|
|
|
os = "Linux " + System.getProperty("os.arch");
|
|
|
|
else if (Platform.isSolaris())
|
|
|
|
os = "SunOS " + System.getProperty("os.version");
|
|
|
|
else if (Platform.isFreeBSD())
|
|
|
|
os = "FreeBSD";
|
|
|
|
else if (Platform.isOpenBSD())
|
|
|
|
os = "OpenBSD";
|
|
|
|
} else if (Platform.isMac()) {
|
|
|
|
wm = "Macintosh";
|
|
|
|
os = System.getProperty("os.name");
|
2011-11-03 07:56:29 -04:00
|
|
|
} else {
|
|
|
|
wm = System.getProperty("os.name");
|
|
|
|
os = System.getProperty("os.name") + " " + System.getProperty("os.version");
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return String.format("%s/%s (%s; U; %s; JRE %s)", getApplicationName(), getApplicationVersion(), wm, os, System.getProperty("java.version"));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String getUserLanguage() {
|
2011-11-03 21:51:33 -04:00
|
|
|
String language = System.getProperty("user.language");
|
|
|
|
|
|
|
|
// user region or country
|
2011-09-21 09:29:21 -04:00
|
|
|
String region = System.getProperty("user.region");
|
|
|
|
if (region == null)
|
|
|
|
region = System.getProperty("user.country");
|
|
|
|
|
2011-11-03 21:51:33 -04:00
|
|
|
// return language string user language with or without user region
|
|
|
|
if (region == null)
|
|
|
|
return language;
|
|
|
|
|
|
|
|
return language + "-" + region;
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String getScreenResolution(GraphicsDevice[] display) {
|
|
|
|
int screenHeight = 0;
|
|
|
|
int screenWidth = 0;
|
|
|
|
|
|
|
|
// get size of each screen
|
|
|
|
for (int i = 0; i < display.length; i++) {
|
|
|
|
DisplayMode dm = display[i].getDisplayMode();
|
|
|
|
screenWidth += dm.getWidth();
|
|
|
|
screenHeight += dm.getHeight();
|
|
|
|
}
|
|
|
|
|
2011-11-03 21:51:33 -04:00
|
|
|
if (screenHeight <= 0 || screenWidth <= 0)
|
2011-09-21 09:29:21 -04:00
|
|
|
throw new HeadlessException("Illegal screen size");
|
|
|
|
|
|
|
|
return screenWidth + "x" + screenHeight;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private static String getColorDepth(GraphicsDevice[] display) {
|
|
|
|
if (display[0] == null)
|
2011-09-24 19:54:39 -04:00
|
|
|
throw new HeadlessException();
|
2011-09-21 09:29:21 -04:00
|
|
|
|
2011-11-03 21:51:33 -04:00
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.append(display[0].getDisplayMode().getBitDepth());
|
2011-09-21 09:29:21 -04:00
|
|
|
for (int i = 1; i < display.length; i++) {
|
2011-11-03 21:51:33 -04:00
|
|
|
sb.append(", ").append(display[i].getDisplayMode().getBitDepth());
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
2011-11-03 21:51:33 -04:00
|
|
|
return sb.toString();
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
private static final String VISITOR_ID = "visitorId";
|
|
|
|
private static final String TIMESTAMP_FIRST = "timestampFirst";
|
|
|
|
private static final String TIMESTAMP_LAST = "timestampLast";
|
|
|
|
private static final String VISITS = "visits";
|
|
|
|
|
|
|
|
|
|
|
|
private synchronized static VisitorData restoreVisitorData() {
|
2011-09-21 09:29:21 -04:00
|
|
|
try {
|
|
|
|
// try to restore visitor
|
2011-11-13 01:49:34 -05:00
|
|
|
Map<String, String> data = getPersistentData();
|
|
|
|
int visitorId = Integer.parseInt(data.get(VISITOR_ID));
|
|
|
|
long timestampFirst = Long.parseLong(data.get(TIMESTAMP_FIRST));
|
|
|
|
long timestampLast = Long.parseLong(data.get(TIMESTAMP_LAST));
|
|
|
|
int visits = Integer.parseInt(data.get(VISITS));
|
2011-09-21 09:29:21 -04:00
|
|
|
|
|
|
|
return VisitorData.newSession(visitorId, timestampFirst, timestampLast, visits);
|
|
|
|
} catch (Exception e) {
|
|
|
|
// new visitor
|
|
|
|
return VisitorData.newVisitor();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
private synchronized static void storeVisitorData(VisitorData visitor) {
|
|
|
|
Map<String, String> data = getPersistentData();
|
|
|
|
data.put(VISITOR_ID, String.valueOf(visitor.getVisitorId()));
|
|
|
|
data.put(TIMESTAMP_FIRST, String.valueOf(visitor.getTimestampFirst()));
|
|
|
|
data.put(TIMESTAMP_LAST, String.valueOf(visitor.getTimestampPrevious()));
|
|
|
|
data.put(VISITS, String.valueOf(visitor.getVisits()));
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-11-13 01:49:34 -05:00
|
|
|
private static Map<String, String> getPersistentData() {
|
|
|
|
return Settings.forPackage(Analytics.class).node("analytics").asMap();
|
2011-09-21 09:29:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2011-10-30 06:36:40 -04:00
|
|
|
* Dummy constructor to prevent instantiation
|
2011-09-21 09:29:21 -04:00
|
|
|
*/
|
|
|
|
private Analytics() {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|