--- misc/xbmc/plugin.video.todic/default.py 2015/07/13 11:15:37 2600 +++ misc/xbmc/plugin.video.todic/default.py 2015/07/13 14:33:39 2601 @@ -18,7 +18,7 @@ import urllib import urllib2 -#import pprint +# import pprint from xml.dom.minidom import parseString @@ -26,358 +26,355 @@ __key__ = __addon__.getSetting('xbmckey').lower() __backend__ = "http://todic.dk/xbmc.php?xbmckey=" + __key__ fanartImage = os.path.join(__addon__.getAddonInfo('path'), 'movie_bg_blur.jpg') -datapath = xbmc.translatePath('special://profile/addon_data/plugin.video.todic/') +datapath = xbmc.translatePath( + 'special://profile/addon_data/plugin.video.todic/') ADDON_PATH = __addon__.getAddonInfo('path') -SkinMasterPath = os.path.join(ADDON_PATH, 'skins' ) + '/' +SkinMasterPath = os.path.join(ADDON_PATH, 'skins') + '/' MySkinPath = (os.path.join(SkinMasterPath, '720p')) + '/' MySkin = 'main.xml' class TodicMovieDialog(xbmcgui.WindowXMLDialog): - def __new__(cls): - return super(TodicMovieDialog, cls).__new__(cls, "main.xml", ADDON_PATH) - def __init__(self): - super(TodicMovieDialog, self).__init__() + def __new__(cls): + return super(TodicMovieDialog, cls).__new__(cls, "main.xml", ADDON_PATH) - def onClick( self, controlId ): - print "OnClick: " + str(controlId) - - if (controlId == 50): - self.close() - play_real_video(self.url, self.name) + def __init__(self): + super(TodicMovieDialog, self).__init__() - if ( controlId == 98 ): - self.close() + def onClick(self, controlId): + print "OnClick: " + str(controlId) + if (controlId == 50): + self.close() + play_real_video(self.url, self.name) - def onInit(self): + if (controlId == 98): + self.close() - print "ONINIT" - self.getControl( 1 ).setLabel( self.name); - self.getControl( 2 ).setLabel( self.moviegroups ) - self.getControl( 3 ).setLabel( self.description ) - self.getControl( 10 ).setLabel( self.playlength ) - self.getControl( 11 ).setLabel( self.codecdetails ) + def onInit(self): - + print "ONINIT" + self.getControl(1).setLabel(self.name) + self.getControl(2).setLabel(self.moviegroups) + self.getControl(3).setLabel(self.description) + self.getControl(10).setLabel(self.playlength) + self.getControl(11).setLabel(self.codecdetails) - orig_img_width = self.getControl(40).getWidth() - self.starwidth = ( float(self.imdbrating) / 10.0) * orig_img_width; - self.getControl(40).setWidth( int(self.starwidth) ) + orig_img_width = self.getControl(40).getWidth() + self.starwidth = (float(self.imdbrating) / 10.0) * orig_img_width + self.getControl(40).setWidth(int(self.starwidth)) - def setUrl( self, url): - print "SETURL:" + url - self.url = url - self.fetchClipDetails() + def setUrl(self, url): + print "SETURL:" + url + self.url = url + self.fetchClipDetails() + def fetchClipDetails(self): + param1 = parse_parameter_string(self.url) - def fetchClipDetails(self): - param1 = parse_parameter_string( self.url ) + self.clipkey = param1["clipkey"] + print "CLIPKEY:" + self.clipkey + detailurl = __backend__ + "&action=clipdetails&clipkey=" + self.clipkey - self.clipkey = param1[ "clipkey" ] - print "CLIPKEY:" + self.clipkey - detailurl = __backend__ + "&action=clipdetails&clipkey=" + self.clipkey - - xml = open_url(detailurl) + xml = open_url(detailurl) - doc = parseString(xml) - self.imdbrating = getText( doc.getElementsByTagName("imdbrating") ) - self.moviegroups = getText( doc.getElementsByTagName("moviegroups") ) - self.playlength = getText( doc.getElementsByTagName("playlength") ) - self.codecdetails = getText( doc.getElementsByTagName("codecdetails") ) + doc = parseString(xml) + self.imdbrating = getText(doc.getElementsByTagName("imdbrating")) + self.moviegroups = getText(doc.getElementsByTagName("moviegroups")) + self.playlength = getText(doc.getElementsByTagName("playlength")) + self.codecdetails = getText(doc.getElementsByTagName("codecdetails")) + def setName(self, name): + self.name = name - - - - def setName( self, name ): - self.name = name - - def setDescription( self, description ): - self.description = description + def setDescription(self, description): + self.description = description class TodicPlayer(xbmc.Player): - def __init__(self, *args, **kwargs): - #xbmc.Player.__init__(selv,*args,**kwargs) - xbmc.Player.__init__(self, xbmc.PLAYER_CORE_MPLAYER ) - self.stopped = False - self.started = False - print "[TodicPlayer] init" - -# @catchall - def onPlayBackStarted(self): - self.started = True - print "[TodicPlayer] : started" + + def __init__(self, *args, **kwargs): + # xbmc.Player.__init__(selv,*args,**kwargs) + xbmc.Player.__init__(self, xbmc.PLAYER_CORE_MPLAYER) + self.stopped = False + self.started = False + print "[TodicPlayer] init" + +# @catchall + def onPlayBackStarted(self): + self.started = True + print "[TodicPlayer] : started" # super.onPlayBackStarted() - def onPlayBackStopped(self): - self.stopped = True - print "[TodicPlayer] : stopped" - - def onPlayBackEnded(self): - self.stopped = True - print "[TodicPlayer] : ended" - - def callbackLoop(self): - print "[Todic] startLoop" - while (self.stopped == False): - if (self.started == True ): - print "[todic] " + str(self.getTime()) - xbmc.sleep(5000) - + def onPlayBackStopped(self): + self.stopped = True + print "[TodicPlayer] : stopped" + + def onPlayBackEnded(self): + self.stopped = True + print "[TodicPlayer] : ended" + + def callbackLoop(self): + print "[Todic] startLoop" + while (self.stopped == False): + if (self.started == True): + print "[todic] " + str(self.getTime()) + xbmc.sleep(5000) + def getText2(nodelist): - rc = [] - for node in nodelist: - if node.nodeType == node.TEXT_NODE: - rc.append(node.data) - else: - rc.append( getText(node.childNodes) ) - return ''.join(rc) + rc = [] + for node in nodelist: + if node.nodeType == node.TEXT_NODE: + rc.append(node.data) + else: + rc.append(getText(node.childNodes)) + return ''.join(rc) + def getText(nodelist): - if nodelist.length == 0: - return '' - else: - if nodelist[0].childNodes.length == 0: - return '' - else: - return nodelist[0].childNodes[0].nodeValue + if nodelist.length == 0: + return '' + else: + if nodelist[0].childNodes.length == 0: + return '' + else: + return nodelist[0].childNodes[0].nodeValue + def SaveFile(path, data): - file = open(path,'w') - file.write(data) - file.close() + file = open(path, 'w') + file.write(data) + file.close() def open_url(url): - req = urllib2.Request(url) - content = urllib2.urlopen(req) - data = content.read() - content.close() - return data - -def rootMenu(): - - msg = open_url(__backend__ + "&action=messages") - msg = msg.strip() - - if msg != "": - dialog = xbmcgui.Dialog() - dialog.ok('XBMC Todic', msg) + req = urllib2.Request(url) + content = urllib2.urlopen(req) + data = content.read() + content.close() + return data - buildList(__backend__, "", False) # call default list - - # Adde xtra items to root menu - listitem = xbmcgui.ListItem(label = "Søg film ...", iconImage = 'DefaultFolder.png', thumbnailImage = 'DefaultFolder.png') - listitem.setProperty('Fanart_Image', fanartImage) - - u = sys.argv[0] + "?mode=10&name=" - ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = True) - - #add search series - listitem = xbmcgui.ListItem(label = "Søg Serier ...", iconImage = 'DefaultFolder.png', thumbnailImage = 'DefaultFolder.png') - listitem.setProperty('Fanart_Image', fanartImage) - - u = sys.argv[0] + "?mode=11&name=" - ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = True) - - xbmcplugin.endOfDirectory(int(sys.argv[1])) - - -def buildList(url,title, endlist=True): - print '[TODIC]:'+str(url) - - link = open_url(url) - doc = parseString(link) - ty = doc.getElementsByTagName("meta")[0].getAttribute("type") - print '[TODIC]'+str(ty) - - if ty == 'clipList': - mode = '50' - folder = False - else: - mode = '1' - folder = True +def rootMenu(): - entries = doc.getElementsByTagName("entry") - l=len(entries) - description = '' - for entry in entries: - name = getText( entry.getElementsByTagName("title") ) - url = getText( entry.getElementsByTagName("url") ) - thumb = getText( entry.getElementsByTagName("cover") ) - description = getText( entry.getElementsByTagName("description") ) - playcount = getText( entry.getElementsByTagName("playcount") ) - - if playcount == '': - playcount = '0' - playcount = int(playcount) + msg = open_url(__backend__ + "&action=messages") + msg = msg.strip() + if msg != "": + dialog = xbmcgui.Dialog() + dialog.ok('XBMC Todic', msg) + + buildList(__backend__, "", False) # call default list + + # Adde xtra items to root menu + listitem = xbmcgui.ListItem( + label="Søg film ...", iconImage='DefaultFolder.png', thumbnailImage='DefaultFolder.png') + listitem.setProperty('Fanart_Image', fanartImage) + + u = sys.argv[0] + "?mode=10&name=" + ok = xbmcplugin.addDirectoryItem( + handle=int(sys.argv[1]), url=u, listitem=listitem, isFolder=True) + + # add search series + listitem = xbmcgui.ListItem( + label="Søg Serier ...", iconImage='DefaultFolder.png', thumbnailImage='DefaultFolder.png') + listitem.setProperty('Fanart_Image', fanartImage) + + u = sys.argv[0] + "?mode=11&name=" + ok = xbmcplugin.addDirectoryItem( + handle=int(sys.argv[1]), url=u, listitem=listitem, isFolder=True) + + xbmcplugin.endOfDirectory(int(sys.argv[1])) + + +def buildList(url, title, endlist=True): + print '[TODIC]:' + str(url) + + link = open_url(url) + doc = parseString(link) + ty = doc.getElementsByTagName("meta")[0].getAttribute("type") + print '[TODIC]' + str(ty) + + if ty == 'clipList': + mode = '50' + folder = False + else: + mode = '1' + folder = True + + entries = doc.getElementsByTagName("entry") + l = len(entries) + description = '' + for entry in entries: + name = getText(entry.getElementsByTagName("title")) + url = getText(entry.getElementsByTagName("url")) + thumb = getText(entry.getElementsByTagName("cover")) + description = getText(entry.getElementsByTagName("description")) + playcount = getText(entry.getElementsByTagName("playcount")) + + if playcount == '': + playcount = '0' + playcount = int(playcount) -## print "name:" + name +# print "name:" + name # print "url:" + url # print "thumb:" + thumb # print "description:" + description + listitem = xbmcgui.ListItem( + label=name, label2='test', iconImage='DefaultFolder.png', thumbnailImage=thumb) + listitem.setProperty('Fanart_Image', fanartImage) + if mode == '50': + infoLabels = {} + infoLabels['title'] = name + infoLabels['plot'] = description + infoLabels['playcount'] = playcount + listitem.setInfo('video', infoLabels) + + name = name.encode('UTF-8') + description = description.encode('UTF-8') + + u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote( + name) + "&url=" + urllib.quote(url) + "&description=" + urllib.quote(description) + ok = xbmcplugin.addDirectoryItem( + handle=int(sys.argv[1]), url=u, listitem=listitem, isFolder=folder, totalItems=l) + + if (endlist == True): + xbmcplugin.endOfDirectory(int(sys.argv[1])) + + +def play_video(url, name, description): + if (description == None or description == ""): + play_real_video(url, name) + else: + d = TodicMovieDialog() + d.setUrl(url) + d.setName(name) + d.setDescription(description) - - listitem = xbmcgui.ListItem(label = name, label2='test', iconImage = 'DefaultFolder.png', thumbnailImage = thumb) - listitem.setProperty('Fanart_Image', fanartImage) - if mode == '50': - infoLabels = {} - infoLabels['title'] = name - infoLabels['plot'] = description - infoLabels['playcount'] = playcount - listitem.setInfo('video', infoLabels) - - name = name.encode('UTF-8') - description = description.encode('UTF-8') - - - u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote(name) + "&url=" + urllib.quote(url) + "&description=" + urllib.quote(description) - ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = folder, totalItems = l) - - if (endlist == True): - xbmcplugin.endOfDirectory(int(sys.argv[1])) - - - - -def play_video(url, name,description): - if (description == None or description == ""): - play_real_video(url,name) - else: - d = TodicMovieDialog() - d.setUrl( url) - d.setName( name ) - d.setDescription( description ) - - d.doModal() + d.doModal() def play_real_video(url, name): - xml = open_url(url) - print 'TODIC url: ' + str(url) - print 'TODIC xml: '+ xml - - doc = parseString(xml) - url = getText( doc.getElementsByTagName("url") ) - - subtitleurl = getText( doc.getElementsByTagName("subtitles") ) - subtitlesfile = os.path.join(datapath,'temp.srt') - - #if old srt file exists delete it first - if os.path.isfile(subtitlesfile): - os.unlink(subtitlesfile) - - print '[TODIC] subs: '+str(subtitleurl) - if len(subtitleurl) > 0: - subtitles = open_url(subtitleurl) - SaveFile(subtitlesfile, subtitles) - print 'TODIC downloaded subtitles' - - - - image = xbmc.getInfoImage( 'ListItem.Thumb' ) - listitem = xbmcgui.ListItem(label = name , iconImage = 'DefaultVideo.png', thumbnailImage = image) - listitem.setInfo( type = "Video", infoLabels={ "Title": name } ) - - player = TodicPlayer(xbmc.PLAYER_CORE_AUTO) - player.play(str(url), listitem) - - #kan ikke loade subtitles hvis foerend playeren koerer - count = 0 - while not xbmc.Player().isPlaying(): - xbmc.sleep(500) - count += 1 - if count > 10: - break - - - if xbmc.Player().isPlaying(): - if os.path.isfile(subtitlesfile): - player.setSubtitles(subtitlesfile) - print 'TODIC started subtitles' - else: - player.disableSubtitles() + xml = open_url(url) + print 'TODIC url: ' + str(url) + print 'TODIC xml: ' + xml + + doc = parseString(xml) + url = getText(doc.getElementsByTagName("url")) + + subtitleurl = getText(doc.getElementsByTagName("subtitles")) + subtitlesfile = os.path.join(datapath, 'temp.srt') + + # if old srt file exists delete it first + if os.path.isfile(subtitlesfile): + os.unlink(subtitlesfile) + + print '[TODIC] subs: ' + str(subtitleurl) + if len(subtitleurl) > 0: + subtitles = open_url(subtitleurl) + SaveFile(subtitlesfile, subtitles) + print 'TODIC downloaded subtitles' + + image = xbmc.getInfoImage('ListItem.Thumb') + listitem = xbmcgui.ListItem( + label=name, iconImage='DefaultVideo.png', thumbnailImage=image) + listitem.setInfo(type="Video", infoLabels={"Title": name}) + + player = TodicPlayer(xbmc.PLAYER_CORE_AUTO) + player.play(str(url), listitem) + + # kan ikke loade subtitles hvis foerend playeren koerer + count = 0 + while not xbmc.Player().isPlaying(): + xbmc.sleep(500) + count += 1 + if count > 10: + break + + if xbmc.Player().isPlaying(): + if os.path.isfile(subtitlesfile): + player.setSubtitles(subtitlesfile) + print 'TODIC started subtitles' + else: + player.disableSubtitles() # player.callbackLoop() - def search(): - search = getUserInput("Todic Søgning") + search = getUserInput("Todic Søgning") - if (search != None and search != ""): - url = __backend__ + "&action=search&search=" + urllib.quote_plus(search) + if (search != None and search != ""): + url = __backend__ + "&action=search&search=" + \ + urllib.quote_plus(search) - #print "[TODIC] Search start: " + search - #print "[TODIC] Search url: " + url + # print "[TODIC] Search start: " + search + # print "[TODIC] Search url: " + url - buildList(url, "søgning") + buildList(url, "søgning") -def searchSeries(): - search = getUserInput("Todic Serie Søgning") - if (search != None and search != ""): - url = __backend__ + "&action=searchseries&search=" + urllib.quote_plus(search) +def searchSeries(): + search = getUserInput("Todic Serie Søgning") - #print "[TODIC] Search start: " + search - #print "[TODIC] Search url: " + url + if (search != None and search != ""): + url = __backend__ + "&action=searchseries&search=" + \ + urllib.quote_plus(search) - buildList(url, "serie søgning") + # print "[TODIC] Search start: " + search + # print "[TODIC] Search url: " + url - + buildList(url, "serie søgning") - -#=================================== Tool Box ======================================= +#=================================== Tool Box ======================================= # shows a more userfriendly notification def showMessage(heading, message): - duration = 15*1000 - xbmc.executebuiltin('XBMC.Notification("%s", "%s", %s)' % ( heading, message, duration) ) + duration = 15 * 1000 + xbmc.executebuiltin('XBMC.Notification("%s", "%s", %s)' % + (heading, message, duration)) # raise a keyboard for user input -def getUserInput(title = "Input", default="", hidden=False): - result = None +def getUserInput(title="Input", default="", hidden=False): + result = None + + # Fix for when this functions is called with default=None + if not default: + default = "" + + keyboard = xbmc.Keyboard(default, title) + keyboard.setHiddenInput(hidden) + keyboard.doModal() + + if keyboard.isConfirmed(): + result = keyboard.getText() - # Fix for when this functions is called with default=None - if not default: - default = "" - - keyboard = xbmc.Keyboard(default, title) - keyboard.setHiddenInput(hidden) - keyboard.doModal() - - if keyboard.isConfirmed(): - result = keyboard.getText() - - return result + return result def get_params(): - return parse_parameter_string( sys.argv[2] ) + return parse_parameter_string(sys.argv[2]) -def parse_parameter_string( paramstring ): - param=[] - if len(paramstring)>=2: - params = paramstring - 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 + +def parse_parameter_string(paramstring): + param = [] + if len(paramstring) >= 2: + params = paramstring + 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 params = get_params() @@ -387,52 +384,49 @@ description = None try: - url = urllib.unquote_plus(params["url"]) + url = urllib.unquote_plus(params["url"]) except: - pass + pass try: - name = urllib.unquote_plus(params["name"]) + name = urllib.unquote_plus(params["name"]) except: - pass + pass try: - mode = int(params["mode"]) + mode = int(params["mode"]) except: - pass + pass try: - description = urllib.unquote_plus(params["description"]) + description = urllib.unquote_plus(params["description"]) except: - pass + pass try: - open_url("http://todic.dk") + open_url("http://todic.dk") except: - showMessage("Fejl", "Kunne ikke forbinde til todic.dk") - exit() - + showMessage("Fejl", "Kunne ikke forbinde til todic.dk") + exit() + if url == 'refresh': - #xbmc.output("[tvserver] Container.Refresh") #20130418 xbmc.output virker ikke med XBMC12 - xbmc.executebuiltin("Container.Refresh") - + # xbmc.output("[tvserver] Container.Refresh") #20130418 xbmc.output virker + # ikke med XBMC12 + xbmc.executebuiltin("Container.Refresh") + elif mode == None: - #build main menu - rootMenu() - + # build main menu + rootMenu() + elif mode == 1: - #build list of movie starting letters - buildList(url, name) + # build list of movie starting letters + buildList(url, name) elif mode == 10: - search() + search() elif mode == 11: - searchSeries() - - -elif mode == 50: - play_video(url, name, description) - - + searchSeries() +elif mode == 50: + play_video(url, name, description)