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'))