script.module.libtorrent/python_libtorrent/functions.py

90 lines
3.6 KiB
Python
Raw Normal View History

2015-07-12 02:01:59 +03:00
#import sys
2015-07-11 12:00:55 +03:00
import os
2015-07-19 03:01:30 +03:00
import xbmc, xbmcgui, xbmcvfs, xbmcaddon
2015-07-11 12:45:24 +03:00
from net import HTTP
2015-07-11 12:00:55 +03:00
2015-07-15 20:39:42 +03:00
__libbaseurl__ = "https://github.com/DiMartinoXBMC/script.module.libtorrent/raw/master/python_libtorrent"
2015-07-19 03:01:30 +03:00
__settings__ = xbmcaddon.Addon(id='script.module.libtorrent')
__version__ = __settings__.getAddonInfo('version')
__plugin__ = __settings__.getAddonInfo('name') + " v." + __version__
2015-07-11 12:00:55 +03:00
__icon__=os.path.join(xbmc.translatePath('special://home'), 'addons',
'script.module.libtorrent', 'icon.png')
2015-07-12 02:01:59 +03:00
#dirname = os.path.join(xbmc.translatePath('special://home'), 'addons', 'script.module.libtorrent')
#sys.path.insert(0, dirname)
from platform_pulsar import get_platform, get_libname
2015-07-11 12:00:55 +03:00
class DownloaderClass():
def __init__(self, dest_path):
self.dest_path = dest_path
self.platform = get_platform()
tempdir(self.platform)
def tools_download(self):
for libname in get_libname(self.platform):
2015-07-11 23:49:53 +03:00
dest = os.path.join(self.dest_path, libname)
2015-07-11 12:45:24 +03:00
log("try to fetch %s" % libname)
url = "%s/%s/%s.zip" % (__libbaseurl__, self.platform['system'], libname)
2015-07-11 23:49:53 +03:00
if libname!='liblibtorrent.so':
try:
self.http = HTTP()
self.http.fetch(url, download=dest + ".zip", progress=True)
log("%s -> %s" % (url, dest))
xbmc.executebuiltin('XBMC.Extract("%s.zip","%s")' % (dest, self.dest_path), True)
xbmcvfs.delete(dest + ".zip")
except:
text = 'Failed download %s!' % libname
2015-07-19 03:01:30 +03:00
xbmc.executebuiltin("XBMC.Notification(%s,%s,%s,%s)" % (__plugin__,text,750,__icon__))
2015-07-11 23:49:53 +03:00
else:
2015-07-12 18:54:43 +03:00
x=xbmcvfs.copy(os.path.join(self.dest_path, 'libtorrent.so'), dest)
2015-07-11 23:49:53 +03:00
return True
2015-07-11 12:00:55 +03:00
def log(msg):
2015-07-16 21:16:03 +03:00
try:
2015-07-19 03:01:30 +03:00
xbmc.log("### [%s]: %s" % (__plugin__,msg,), level=xbmc.LOGNOTICE )
2015-07-16 21:16:03 +03:00
except UnicodeEncodeError:
2015-07-19 03:01:30 +03:00
xbmc.log("### [%s]: %s" % (__plugin__,msg.encode("utf-8", "ignore"),), level=xbmc.LOGNOTICE )
2015-07-16 21:16:03 +03:00
except:
2015-07-19 03:01:30 +03:00
xbmc.log("### [%s]: %s" % (__plugin__,'ERROR LOG',), level=xbmc.LOGNOTICE )
2015-07-11 12:00:55 +03:00
def tempdir(platform):
dirname=xbmc.translatePath('special://temp')
for subdir in ('xbmcup', 'script.module.libtorrent', 'python_libtorrent', platform['system']):
dirname = os.path.join(dirname, subdir)
if not xbmcvfs.exists(dirname):
xbmcvfs.mkdir(dirname)
return dirname
class LibraryManager():
def __init__(self, dest_path):
self.dest_path = dest_path
self.platform = get_platform()
2015-07-11 23:49:53 +03:00
self.root=os.path.dirname(__file__)
2015-07-11 12:00:55 +03:00
def check_exist(self):
for libname in get_libname(self.platform):
if not xbmcvfs.exists(os.path.join(self.dest_path,libname)):
return False
return True
def check_update(self):
2015-07-11 23:49:53 +03:00
need_update=False
for libname in get_libname(self.platform):
if libname!='liblibtorrent.so':
self.libpath = os.path.join(self.dest_path, libname)
self.sizepath=os.path.join(self.root, self.platform['system'], libname+'.size.txt')
size=str(os.path.getsize(self.libpath))
size_old=open( self.sizepath, "r" ).read()
if size_old!=size:
need_update=True
return need_update
2015-07-11 12:00:55 +03:00
def update(self):
if self.check_update():
2015-07-11 23:49:53 +03:00
for libname in get_libname(self.platform):
self.libpath = os.path.join(self.dest_path, libname)
xbmcvfs.delete(self.libpath)
self.download()
def download(self):
DownloaderClass(self.dest_path).tools_download()