mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2025-01-13 19:46:13 +00:00
f6f6ae81e4
use the error type in the event action and the file and line in the event label
84 lines
No EOL
2.7 KiB
Python
84 lines
No EOL
2.7 KiB
Python
import sys
|
|
import os
|
|
import requests
|
|
import logging
|
|
import clientinfo
|
|
import md5
|
|
from utils import window, settings, language as lang
|
|
|
|
log = logging.getLogger("EMBY."+__name__)
|
|
|
|
class GoogleAnalytics():
|
|
|
|
testing = False
|
|
|
|
def __init__(self):
|
|
|
|
client_info = clientinfo.ClientInfo()
|
|
self.version = client_info.get_version()
|
|
self.device_id = client_info.get_device_id()
|
|
self.device_name = client_info.get_device_name() + "-" + client_info.get_platform()
|
|
|
|
# Use set user name
|
|
self.user_name = settings('username') or settings('connectUsername') or 'None'
|
|
|
|
# use md5 for client and user for analytics
|
|
self.device_id = md5.new(self.device_id).hexdigest()
|
|
self.user_name = md5.new(self.user_name).hexdigest()
|
|
|
|
def formatException(self):
|
|
exc_type, exc_obj, exc_tb = sys.exc_info()
|
|
fname = os.path.split(exc_tb.tb_frame.f_code.co_filename)[1]
|
|
errorFile = "%s:%s" % (fname, exc_tb.tb_lineno)
|
|
errorType = "%s" % (exc_type.__name__)
|
|
del(exc_type, exc_obj, exc_tb)
|
|
log.error(errorType + " - " + errorFile)
|
|
return errorType, errorFile
|
|
|
|
def sendEventData(self, eventCategory, eventAction, eventLabel=None):
|
|
|
|
if(settings('metricLogging') == "false"):
|
|
return
|
|
|
|
# for info on the metrics that can be sent to Google Analytics
|
|
# https://developers.google.com/analytics/devguides/collection/protocol/v1/parameters#events
|
|
|
|
# all the data we can send to Google Analytics
|
|
data = {}
|
|
data['v'] = '1'
|
|
data['tid'] = 'UA-85356267-1' # tracking id, this is the account ID
|
|
|
|
data['ds'] = 'plugin' # data source
|
|
|
|
data['an'] = 'Kodi4Emby' # App Name
|
|
data['aid'] = '1' # App ID
|
|
data['av'] = self.version # App Version
|
|
#data['aiid'] = '1.1' # App installer ID
|
|
|
|
data['cid'] = self.device_id # Client ID
|
|
data['uid'] = self.user_name # User ID
|
|
|
|
data['ua'] = self.device_name # user agent string
|
|
|
|
data['t'] = 'event' # action type
|
|
data['ec'] = eventCategory # Event Category
|
|
data['ea'] = eventAction # Event Action
|
|
|
|
if(eventLabel != None):
|
|
data['el'] = eventLabel # Event Label
|
|
|
|
log.info("GA: " + str(data))
|
|
|
|
if(self.testing):
|
|
url = "https://www.google-analytics.com/debug/collect" # test URL
|
|
else:
|
|
url = "https://www.google-analytics.com/collect" # prod URL
|
|
|
|
try:
|
|
r = requests.post(url, data)
|
|
except Exception as error:
|
|
log.error(error)
|
|
|
|
if(self.testing):
|
|
log.info("GA: " + r.text.encode('utf-8'))
|
|
|