test
This commit is contained in:
BIN
lib/usage/__pycache__/googletracker.cpython-38.opt-1.pyc
Normal file
BIN
lib/usage/__pycache__/googletracker.cpython-38.opt-1.pyc
Normal file
Binary file not shown.
BIN
lib/usage/__pycache__/tracker.cpython-38.opt-1.pyc
Normal file
BIN
lib/usage/__pycache__/tracker.cpython-38.opt-1.pyc
Normal file
Binary file not shown.
BIN
lib/usage/__pycache__/utmain.cpython-38.opt-1.pyc
Normal file
BIN
lib/usage/__pycache__/utmain.cpython-38.opt-1.pyc
Normal file
Binary file not shown.
74
lib/usage/googletracker.py
Normal file
74
lib/usage/googletracker.py
Normal file
@@ -0,0 +1,74 @@
|
||||
# -*- coding: UTF-8 -*-
|
||||
#/*
|
||||
# * Copyright (C) 2011 Libor Zoubek
|
||||
# *
|
||||
# *
|
||||
# * This Program is free software; you can redistribute it and/or modify
|
||||
# * it under the terms of the GNU General Public License as published by
|
||||
# * the Free Software Foundation; either version 2, or (at your option)
|
||||
# * any later version.
|
||||
# *
|
||||
# * This Program is distributed in the hope that it will be useful,
|
||||
# * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# * GNU General Public License for more details.
|
||||
# *
|
||||
# * You should have received a copy of the GNU General Public License
|
||||
# * along with this program; see the file COPYING. If not, write to
|
||||
# * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
# * http://www.gnu.org/copyleft/gpl.html
|
||||
# *
|
||||
# */
|
||||
import os,re,sys,urllib.request,urllib.parse,urllib.error,urllib.request,urllib.error,urllib.parse,traceback,http.cookiejar,random,time
|
||||
UA='Mozilla/5.0 (Windows; U; Windows NT 5.1; en-GB; rv:1.9.0.3) Gecko/2008092417 Firefox/3.0.3'
|
||||
|
||||
TRACKER_URL='http://www.google-analytics.com/__utm.gif'
|
||||
__name__ = 'google'
|
||||
##
|
||||
# initializes urllib cookie handler
|
||||
def init_urllib():
|
||||
cj = http.cookiejar.LWPCookieJar()
|
||||
opener = urllib.request.build_opener(urllib.request.HTTPCookieProcessor(cj))
|
||||
urllib.request.install_opener(opener)
|
||||
|
||||
def _request(url,info):
|
||||
# setup useragent!!
|
||||
print('[google] Submiting usage')
|
||||
req = urllib.request.Request(url)
|
||||
req.add_header('User-Agent',info['useragent'])
|
||||
response = urllib.request.urlopen(req)
|
||||
data = response.read()
|
||||
if 200 == response.code:
|
||||
print('[google] Usage has been submitted')
|
||||
response.close()
|
||||
|
||||
def _get_cookie(info):
|
||||
return '__utma='+'.'.join(info['instanceid'])+'.8;+__utmz='+info['instanceid'][0]+'.'+info['instanceid'][-1]+'.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none)|utmctr=(none)'
|
||||
|
||||
def createInstanceID():
|
||||
return [str(random.randint(0,99999999)),str(random.randint(0,9999999999)),str(random.randint(0,9999999999)),str(random.randint(0,9999999999)),str(random.randint(0,9999999999))]
|
||||
|
||||
|
||||
def track_usage(url,action,trackingCode,dry,info):
|
||||
params = {
|
||||
'utmac':trackingCode,
|
||||
'utms':'1', # number of 'clicks'
|
||||
'utmcs':'UTF-8', # system encoding
|
||||
'utmdt':action, # page title
|
||||
'utmhn':url, # url-encoded target url
|
||||
'utmhid':random.randint(0,9999999999), #random number
|
||||
'utmje':'0', # do we have java? 1 = yes, 0 = no
|
||||
'utmn':time.time(), # unique for each request to avoid caching
|
||||
'utmp':'/'+action, # page that has been visited
|
||||
'utmsc':info['colordepth'], # color depth
|
||||
'utmsr':info['resolution'], # screen resolution
|
||||
'utmul':info['language'], # system language
|
||||
'utmr':'-', # referal - 0 = none
|
||||
'utmwv':'5.2.2', # version of tracking client
|
||||
'utmcc':_get_cookie(info),
|
||||
'utmu':'q~' # what is this about?
|
||||
}
|
||||
req = TRACKER_URL+'?'+urllib.parse.urlencode(params)
|
||||
if not dry:
|
||||
_request(req,info)
|
||||
|
||||
231
lib/usage/tracker.py
Normal file
231
lib/usage/tracker.py
Normal file
@@ -0,0 +1,231 @@
|
||||
# -*- coding: UTF-8 -*-
|
||||
#/*
|
||||
# * Copyright (C) 2011 Libor Zoubek
|
||||
# *
|
||||
# *
|
||||
# * This Program is free software; you can redistribute it and/or modify
|
||||
# * it under the terms of the GNU General Public License as published by
|
||||
# * the Free Software Foundation; either version 2, or (at your option)
|
||||
# * any later version.
|
||||
# *
|
||||
# * This Program is distributed in the hope that it will be useful,
|
||||
# * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# * GNU General Public License for more details.
|
||||
# *
|
||||
# * You should have received a copy of the GNU General Public License
|
||||
# * along with this program; see the file COPYING. If not, write to
|
||||
# * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
# * http://www.gnu.org/copyleft/gpl.html
|
||||
# *
|
||||
# */
|
||||
import json
|
||||
import xbmc
|
||||
import xbmcvfs
|
||||
import os
|
||||
import random
|
||||
import sys
|
||||
import traceback
|
||||
import xbmcutil
|
||||
|
||||
import googletracker
|
||||
|
||||
|
||||
class TrackerSettings(object):
|
||||
|
||||
def __init__(self, addon):
|
||||
self.services = [googletracker]
|
||||
local = xbmcvfs.translatePath(addon.getAddonInfo('profile'))
|
||||
if not os.path.exists(local):
|
||||
os.makedirs(local)
|
||||
self.settingFile = os.path.join(local, 'tracking.json')
|
||||
|
||||
if os.path.exists(self.settingFile):
|
||||
f = open(self.settingFile, 'r')
|
||||
file_content = f.read()
|
||||
f.close()
|
||||
try:
|
||||
self.data = json.loads(file_content)
|
||||
except:
|
||||
self.data = {}
|
||||
self.data['id'] = {}
|
||||
for serv in self.services:
|
||||
self.data['id'][serv.__name__] = serv.createInstanceID()
|
||||
self.data['addons'] = {}
|
||||
self.save()
|
||||
|
||||
for serv in self.services:
|
||||
if not serv.__name__ in list(self.data['id'].keys()):
|
||||
self.data['id'][serv.__name__] = serv.createInstanceID()
|
||||
self.save()
|
||||
else:
|
||||
self.data = {}
|
||||
self.data['id'] = {}
|
||||
for serv in self.services:
|
||||
self.data['id'][serv.__name__] = serv.createInstanceID()
|
||||
self.data['addons'] = {}
|
||||
self.save()
|
||||
|
||||
def save(self):
|
||||
f = open(self.settingFile, 'w')
|
||||
f.write(json.dumps(self.data, ensure_ascii=True))
|
||||
f.close()
|
||||
|
||||
def getInstanceID(self, service):
|
||||
return self.data['id'][service]
|
||||
|
||||
def isReportingEnabled(self):
|
||||
if 'report-enabled' in self.data:
|
||||
return self.data['report-enabled']
|
||||
|
||||
def setReportingEnabled(self, value):
|
||||
self.data['report-enabled'] = value
|
||||
|
||||
def getTermsStringID(self, addon):
|
||||
subscribers = self.getSubscribers()
|
||||
if addon in subscribers:
|
||||
return subscribers[addon]['terms']
|
||||
|
||||
def getSubscribers(self):
|
||||
return self.data['addons']
|
||||
|
||||
def addAddon(self, addon, subscribed, conditions):
|
||||
self.data['addons'][addon] = {}
|
||||
self.data['addons'][addon]['enabled'] = subscribed
|
||||
self.data['addons'][addon]['terms'] = conditions
|
||||
self.save()
|
||||
|
||||
|
||||
class TrackerInfo(object):
|
||||
|
||||
def __init__(self):
|
||||
pass
|
||||
|
||||
def _getUserAgent(self, version, language):
|
||||
platform = sys.platform
|
||||
sp = version.find(' ')
|
||||
if sp > 0:
|
||||
version = version[:sp]
|
||||
if platform.startswith('linux'):
|
||||
return 'KODI/%s (X11; U; Linux i686; %s)' % (version, language)
|
||||
if platform.startswith('win'):
|
||||
return 'KODI/%s (Windows; U; Windows NT; %s)' % (version, language)
|
||||
if platform.startswith('darwin'):
|
||||
return 'KODI/%s (Mac; U; Intel Mac OS X; %s)' % (version, language)
|
||||
else:
|
||||
print('[script.usage.tracker] Unknown platform %s, please report a bug, plugin needs to be fixed' % sys.platform)
|
||||
return 'KODI/%s (X11; U; Unknown i686; %s)' % (version, language)
|
||||
|
||||
def getSystemInfo(self):
|
||||
# some stupid defaults
|
||||
info = {'colordepth': '24-bit', 'resolution': '640x480',
|
||||
'language': 'en', 'useragent': self._getUserAgent('Unknown', 'en')}
|
||||
|
||||
# get info via JSON RPC, try to be compatible with both dharma & eden APIs
|
||||
try:
|
||||
data = xbmc.executeJSONRPC(
|
||||
'{"jsonrpc": "2.0", "method": "System.GetInfoLabels", "id":1,"params": ["System.BuildVersion","System.ScreenHeight","System.ScreenWidth","System.KenrelVersion","System.Language"]}')
|
||||
data = json.loads(data)
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
if not 'result' in data:
|
||||
data = xbmc.executeJSONRPC(
|
||||
'{"jsonrpc" : "2.0", "method": "XBMC.GetInfoLabels", "id" :1, "params": {"labels" : ["System.BuildVersion","System.ScreenHeight","System.ScreenWidth","System.KenrelVersion","System.Language"]}}')
|
||||
data = json.loads(data)
|
||||
except:
|
||||
pass
|
||||
# process results
|
||||
try:
|
||||
info['resolution'] = '%sx%s' % (data['result']['System.ScreenWidth'], data[
|
||||
'result']['System.ScreenHeight'])
|
||||
info['language'] = getLanguageCode(data['result']['System.Language'])
|
||||
info['useragent'] = self._getUserAgent(
|
||||
data['result']['System.BuildVersion'], info['language'])
|
||||
except:
|
||||
traceback.print_exc()
|
||||
return info
|
||||
|
||||
|
||||
def getLanguageCode(id):
|
||||
languages = {
|
||||
"none": "none",
|
||||
"albanian": "sq",
|
||||
"arabic": "ar",
|
||||
"belarusian": "hy",
|
||||
"bosnian": "bs",
|
||||
"bosnianLatin": "bs",
|
||||
"bulgarian": "bg",
|
||||
"catalan": "ca",
|
||||
"chinese": "zh",
|
||||
"croatian": "hr",
|
||||
"czech": "cs",
|
||||
"danish": "da",
|
||||
"dutch": "nl",
|
||||
"english": "en",
|
||||
"esperanto": "eo",
|
||||
"Estonian": "et",
|
||||
"farsi": "fa",
|
||||
"persian": "fa",
|
||||
"finnish": "fi",
|
||||
"french": "fr",
|
||||
"galician": "gl",
|
||||
"georgian": "ka",
|
||||
"german": "de",
|
||||
"greek": "el",
|
||||
"hebrew": "he",
|
||||
"hindi": "hi",
|
||||
"hungarian": "hu",
|
||||
"icelandic": "is",
|
||||
"indonesian": "id",
|
||||
"italian": "it",
|
||||
"japanese": "ja",
|
||||
"kazakh": "kk",
|
||||
"korean": "ko",
|
||||
"latvian": "lv",
|
||||
"lithuanian": "lt",
|
||||
"luxembourgish": "lb",
|
||||
"macedonian": "mk",
|
||||
"malay": "ms",
|
||||
"norwegian": "no",
|
||||
"occitan": "oc",
|
||||
"polish": "pl",
|
||||
"portuguese": "pt",
|
||||
"portuguesebrazil": "pb",
|
||||
"portuguese (brazil)": "pb",
|
||||
"brazilian": "pb",
|
||||
"romanian": "ro",
|
||||
"russian": "ru",
|
||||
"serbianLatin": "sr",
|
||||
"serbian": "sr",
|
||||
"serbian (syrillic)": "sr",
|
||||
"slovak": "sk",
|
||||
"slovenian": "sl",
|
||||
"spanish": "es",
|
||||
"swedish": "sv",
|
||||
"syriac": "syr",
|
||||
"thai": "th",
|
||||
"turkish": "tr",
|
||||
"ukrainian": "uk",
|
||||
"urdu": "ur",
|
||||
"vietnamese": "vi",
|
||||
"english (us)": "en",
|
||||
"english (uk)": "en",
|
||||
"portuguese (brazilian)": "pt-br",
|
||||
"español (latinoamérica)": "es",
|
||||
"español (españa)": "es",
|
||||
"spanish (latin America)": "es",
|
||||
"español": "es",
|
||||
"spanish": "es",
|
||||
"spanish (mexico)": "es",
|
||||
"spanish (spain)": "es",
|
||||
"chinese (traditional)": "zh",
|
||||
"chinese (simplified)": "zh",
|
||||
"portuguese-br": "pb",
|
||||
"all": "all"
|
||||
}
|
||||
id = id.lower()
|
||||
if id in languages:
|
||||
return languages[id]
|
||||
print('[script.usage.tracker] Cannot detect language code from language: %s, please report a bug, plugin needs to be fixed' % id)
|
||||
return id
|
||||
107
lib/usage/utmain.py
Normal file
107
lib/usage/utmain.py
Normal file
@@ -0,0 +1,107 @@
|
||||
# -*- coding: UTF-8 -*-
|
||||
#/*
|
||||
# * Copyright (C) 2011 Libor Zoubek
|
||||
# *
|
||||
# *
|
||||
# * This Program is free software; you can redistribute it and/or modify
|
||||
# * it under the terms of the GNU General Public License as published by
|
||||
# * the Free Software Foundation; either version 2, or (at your option)
|
||||
# * any later version.
|
||||
# *
|
||||
# * This Program is distributed in the hope that it will be useful,
|
||||
# * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# * GNU General Public License for more details.
|
||||
# *
|
||||
# * You should have received a copy of the GNU General Public License
|
||||
# * along with this program; see the file COPYING. If not, write to
|
||||
# * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
# * http://www.gnu.org/copyleft/gpl.html
|
||||
# *
|
||||
# */
|
||||
import os
|
||||
import re
|
||||
import sys
|
||||
import urllib.request, urllib.parse, urllib.error
|
||||
import urllib.request, urllib.error, urllib.parse
|
||||
import traceback
|
||||
import http.cookiejar
|
||||
import xbmc
|
||||
import xbmcaddon
|
||||
import xbmcgui
|
||||
|
||||
__addon__ = xbmcaddon.Addon(id='script.module.stream.resolver')
|
||||
__ = __addon__.getLocalizedString
|
||||
import googletracker
|
||||
import tracker
|
||||
|
||||
|
||||
def trackUsage(params):
|
||||
for param in ['id', 'host', 'tc']:
|
||||
if not param in params:
|
||||
raise Exception(param + ' param is required')
|
||||
if not 'service' in params:
|
||||
params['service'] = 'google'
|
||||
if not 'cond' in params:
|
||||
params['cond'] = -1
|
||||
else:
|
||||
try:
|
||||
params['cond'] = int(params['cond'])
|
||||
except:
|
||||
pass
|
||||
if not 'action' in params:
|
||||
params['action'] = params['id']
|
||||
if 'dry' in params:
|
||||
try:
|
||||
params['dry'] = bool(params['dry'])
|
||||
except:
|
||||
params['dry'] = False
|
||||
else:
|
||||
params['dry'] = False
|
||||
|
||||
xbmc.log(msg='Parsed input params %s' % (str(params)), level=xbmc.LOGDEBUG)
|
||||
|
||||
try:
|
||||
if not xbmcaddon.Addon(params['id']).getAddonInfo('id') == params['id']:
|
||||
raise Exception('')
|
||||
except:
|
||||
print('Unable to create addon instance for %s, invalid addon ID?!' % (params['id']))
|
||||
return
|
||||
|
||||
if register(params):
|
||||
print('Tracking usage ...')
|
||||
sett = tracker.TrackerSettings(__addon__)
|
||||
info = tracker.TrackerInfo().getSystemInfo()
|
||||
# retrieve per-installation-unique ID
|
||||
info['instanceid'] = sett.getInstanceID(params['service'])
|
||||
if 'google' == params['service']:
|
||||
return googletracker.track_usage(params['host'], params['action'], params['tc'], params['dry'], info)
|
||||
else:
|
||||
print('Reporting for %s disabled by user' % (params['id']))
|
||||
|
||||
|
||||
def register(params):
|
||||
sett = tracker.TrackerSettings(__addon__)
|
||||
enabled = sett.isReportingEnabled()
|
||||
if enabled == None:
|
||||
ret = xbmcgui.Dialog().yesno('KODI CZSK', __(30015))
|
||||
enabled = ret == 1
|
||||
sett.setReportingEnabled(enabled)
|
||||
sett.save()
|
||||
return enabled
|
||||
|
||||
|
||||
def main(p={}):
|
||||
if 'do' in p:
|
||||
if p['do'] == 'reg':
|
||||
if not 'id' in p:
|
||||
raise Exception('id param is required')
|
||||
if not 'cond' in p:
|
||||
p['cond'] = -1
|
||||
else:
|
||||
try:
|
||||
p['cond'] = int(p['cond'])
|
||||
except:
|
||||
pass
|
||||
return register(p)
|
||||
trackUsage(p)
|
||||
Reference in New Issue
Block a user