diff options
Diffstat (limited to 'plugin.video.cheddar/resources/lib/cheddar.py')
-rw-r--r-- | plugin.video.cheddar/resources/lib/cheddar.py | 181 |
1 files changed, 75 insertions, 106 deletions
diff --git a/plugin.video.cheddar/resources/lib/cheddar.py b/plugin.video.cheddar/resources/lib/cheddar.py index 7e2e634..5e5f531 100644 --- a/plugin.video.cheddar/resources/lib/cheddar.py +++ b/plugin.video.cheddar/resources/lib/cheddar.py @@ -1,4 +1,4 @@ -# Copyright (C) 2017 Lunatixz +# Copyright (C) 2018 Lunatixz # # # This file is part of Cheddar @@ -17,10 +17,12 @@ # along with Cheddar. If not, see <http://www.gnu.org/licenses/>. # -*- coding: utf-8 -*- -import os, sys, datetime, re, traceback, urllib, urllib2, socket +import os, sys, datetime, re, traceback +import urlparse, urllib, urllib2, socket import xbmc, xbmcvfs, xbmcgui, xbmcplugin, xbmcaddon -from simplecache import SimpleCache +from YDStreamExtractor import getVideoInfo +from simplecache import SimpleCache, use_cache from bs4 import BeautifulSoup # Plugin Info @@ -35,38 +37,25 @@ FANART = REAL_SETTINGS.getAddonInfo('fanart') LANGUAGE = REAL_SETTINGS.getLocalizedString ## GLOBALS ## -TIMEOUT = 30 -BASEURL = 'http://cheddar.com/' -DEBUG = REAL_SETTINGS.getSetting('Enable_Debugging') == 'true' -CONTENT_TYPE = 'files' - -Cheddar_MENU = [("Latest" , 'collections/latest', 1), - ("Browse" , 'collections' , 1)] +TIMEOUT = 30 +BASEURL = 'http://cheddar.com/' +DEBUG = REAL_SETTINGS.getSetting('Enable_Debugging') == 'true' +QUALITY = int(REAL_SETTINGS.getSetting('Quality')) +CONTENT_TYPE = 'episodes' +Cheddar_MENU = [("Latest" , 'collections/latest', 1), + ("Browse" , 'collections' , 1)] + def log(msg, level=xbmc.LOGDEBUG): - if DEBUG == True: - if level == xbmc.LOGERROR: - msg += ' ,' + traceback.format_exc() - xbmc.log(ADDON_ID + '-' + ADDON_VERSION + '-' + msg, level) - + if DEBUG == False and level != xbmc.LOGERROR: return + if level == xbmc.LOGERROR: msg += ' ,' + traceback.format_exc() + xbmc.log(ADDON_ID + '-' + ADDON_VERSION + '-' + msg, level) + def getParams(): - param=[] - if len(sys.argv[2])>=2: - params=sys.argv[2] - cleanedparams=params.replace('?','') - if (params[len(params)-1]=='/'): - params=params[0:len(params)-2] - pairsofparams=cleanedparams.split('&') - param={} - for i in range(len(pairsofparams)): - splitparams={} - splitparams=pairsofparams[i].split('=') - if (len(splitparams))==2: - param[splitparams[0]]=splitparams[1] - return param - + return dict(urlparse.parse_qsl(sys.argv[2][1:])) + socket.setdefaulttimeout(TIMEOUT) -class Cheddar(): +class Cheddar(object): def __init__(self): log('__init__') self.cache = SimpleCache() @@ -83,84 +72,75 @@ class Cheddar(): response.close() self.cache.set(ADDON_NAME + '.openURL, url = %s'%url, results, expiration=datetime.timedelta(hours=12)) return self.cache.get(ADDON_NAME + '.openURL, url = %s'%url) - except urllib2.URLError as e: - log("openURL Failed! " + str(e), xbmc.LOGERROR) - except socket.timeout as e: - log("openURL Failed! " + str(e), xbmc.LOGERROR) - except: - xbmcgui.Dialog().notification(ADDON_NAME, LANGUAGE(30001), ICON, 4000) - + except urllib2.URLError as e: log("openURL Failed! " + str(e), xbmc.LOGERROR) + except socket.timeout as e: log("openURL Failed! " + str(e), xbmc.LOGERROR) + xbmcgui.Dialog().notification(ADDON_NAME, LANGUAGE(30001), ICON, 4000) + return '' + def mainMenu(self): log('mainMenu') self.addLink('Live', '', 0) - for item in Cheddar_MENU: - self.addDir(*item) + for item in Cheddar_MENU: self.addDir(*item) + self.addYoutube("Browse Youtube" , 'plugin://plugin.video.youtube/channel/UC04KsGq3npibMCE9Td3mVDg/') def browseLive(self): log('browseLive') soup = BeautifulSoup(self.openURL(BASEURL), "html.parser") - liveLink = 'http:' + soup('div', {'class': 'hero_video'})[0].find('source').get('src') + liveLink = soup('div', {'class': 'hero_video'})[0].find('source').get('src') self.playVideo('Live', liveLink) def browse(self, link): log('browse') - soup = BeautifulSoup(self.openURL(BASEURL+link), "html.parser") + soup = BeautifulSoup(self.openURL(BASEURL + link), "html.parser") latestLink = (soup('div', {'class': 'video_thumb'})) for item in latestLink: - try: - uriLink = item('a', {'class': 'cf'})[0] - uri = BASEURL + uriLink['href'] - thumb = uriLink('div', {'class': 'vid_img'})[0].find_all('img')[0].get('src') - airdate, title = uriLink.text.strip().replace('\r','').replace('\t','').split('\n') - plot = 'Aired: %s'%airdate - label = title.strip() - airdate = datetime.datetime.strptime(airdate, "%B %d, %Y") - infoList = {"mediatype":'video',"label":label,"title":label,"plot":plot,'genre':'News',"studio":"cheddar","aired":airdate.strftime('%Y-%m-%d'),"date":airdate.strftime('%d/%m/%Y')} - infoArt = {"thumb":thumb,"poster":thumb,"fanart":FANART} - self.addLink(label, uri, 9, infoList, infoArt) - except: - xbmc.executebuiltin("Container.Refresh") - - - def playVideo(self, name, uri): - log('playVideo, uri = ' + uri) - try: - metaLink = BeautifulSoup(self.openURL(uri), "html.parser") - meta = metaLink('div', {'class': 'wrap video_details'})[0]('div', {'class': 'video_details_content'})[0] - title = meta.find('h4').text - plot = meta.find('article').text - airdate = meta.find('p').text - plotout = 'Aired: %s'%airdate - airdate = datetime.datetime.strptime(airdate, "%B %d, %Y") - url = metaLink('div', {'class': 'hero_video'})[0].find('source').get('src')+'.mp4' - thumb = metaLink('div', {'class': 'hero_video'})[0].find('video').get('poster') - infoList = {"mediatype":'video',"label":title,"title":title,"plot":plot,'genre':'News',"plotoutline":plotout,"studio":"cheddar","aired":airdate.strftime('%Y-%m-%d')} + uriLink = item('a', {'class': 'cf'})[0] + uri = BASEURL + uriLink['href'] + thumb = uriLink('div', {'class': 'vid_img'})[0].find_all('img')[0].get('src') + airdate, title = uriLink.text.strip().replace('\r','').replace('\t','').split('\n') + label = title.strip() + plot = '%s [CR]Aired: %s'%(label, airdate) + try: airdate = datetime.datetime.strptime(airdate, "%B %d, %Y") + except: airdate = datetime.datetime.now() + airdate = airdate.strftime('%Y-%m-%d') + infoList = {"mediatype":"episode","label":label,"title":label,"plot":plot,'genre':'News',"studio":"cheddar","aired":airdate} infoArt = {"thumb":thumb,"poster":thumb,"fanart":FANART} - liz = xbmcgui.ListItem(title, path=url) - liz.setInfo(type="Video", infoLabels=infoList) - liz.setArt(infoArt) - except: - liz = xbmcgui.ListItem(name, path=uri) - xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, liz) + self.addLink(label, uri, 9, infoList, infoArt) + + def playVideo(self, name, url): + log('playVideo, name = ' + name) + if name == 'Live': liz = xbmcgui.ListItem(name, path=url) + else: + info = getVideoInfo(url,QUALITY,True) + if info is None: return + info = info.streams() + url = info[0]['xbmc_url'] + liz = xbmcgui.ListItem(name, path=url) + if 'subtitles' in info[0]['ytdl_format']: liz.setSubtitles([x['url'] for x in info[0]['ytdl_format']['subtitles'].get('en','') if 'url' in x]) + xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, liz) + + + def addYoutube(self, name, url): + liz=xbmcgui.ListItem(name) + liz.setProperty('IsPlayable', 'false') + liz.setInfo(type="Video", infoLabels={"label":name,"title":name} ) + liz.setArt({'thumb':ICON,'fanart':FANART}) + xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=url,listitem=liz,isFolder=True) + def addLink(self, name, u, mode, infoList=False, infoArt=False, total=0): name = name.encode("utf-8") log('addLink, name = ' + name) liz=xbmcgui.ListItem(name) liz.setProperty('IsPlayable', 'true') - if infoList == False: - liz.setInfo(type="Video", infoLabels={"mediatype":"video","label":name,"title":name}) - else: - liz.setInfo(type="Video", infoLabels=infoList) - - if infoArt == False: - liz.setArt({'thumb':ICON,'fanart':FANART}) - else: - liz.setArt(infoArt) + if infoList == False: liz.setInfo(type="Video", infoLabels={"mediatype":"video","label":name,"title":name}) + else: liz.setInfo(type="Video", infoLabels=infoList) + if infoArt == False: liz.setArt({'thumb':ICON,'fanart':FANART}) + else: liz.setArt(infoArt) u=sys.argv[0]+"?url="+urllib.quote_plus(u)+"&mode="+str(mode)+"&name="+urllib.quote_plus(name) xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=u,listitem=liz,totalItems=total) @@ -170,31 +150,20 @@ class Cheddar(): log('addDir, name = ' + name) liz=xbmcgui.ListItem(name) liz.setProperty('IsPlayable', 'false') - if infoList == False: - liz.setInfo(type="Video", infoLabels={"mediatype":"video","label":name,"title":name} ) - else: - liz.setInfo(type="Video", infoLabels=infoList) - if infoArt == False: - liz.setArt({'thumb':ICON,'fanart':FANART}) - else: - liz.setArt(infoArt) + if infoList == False: liz.setInfo(type="Video", infoLabels={"mediatype":"video","label":name,"title":name} ) + else: liz.setInfo(type="Video", infoLabels=infoList) + if infoArt == False: liz.setArt({'thumb':ICON,'fanart':FANART}) + else: liz.setArt(infoArt) u=sys.argv[0]+"?url="+urllib.quote_plus(u)+"&mode="+str(mode)+"&name="+urllib.quote_plus(name) xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=u,listitem=liz,isFolder=True) params=getParams() -try: - url=urllib.unquote_plus(params["url"]) -except: - url=None -try: - name=urllib.unquote_plus(params["name"]) -except: - name=None -try: - mode=int(params["mode"]) -except: - mode=None - +try: url=urllib.unquote_plus(params["url"]) +except: url=None +try: name=urllib.unquote_plus(params["name"]) +except: name=None +try: mode=int(params["mode"]) +except: mode=None log("Mode: "+str(mode)) log("URL : "+str(url)) log("Name: "+str(name)) |