/[projects]/misc/xbmc/plugin.video.todic/default.py
ViewVC logotype

Annotation of /misc/xbmc/plugin.video.todic/default.py

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3250 - (hide annotations) (download) (as text)
Thu Feb 28 11:03:28 2019 UTC (5 years, 3 months ago) by torben
File MIME type: text/x-python
File size: 14664 byte(s)
simplify subtitle handling
1 torben 1678
2 torben 1677 # This Python file uses the following encoding: utf-8
3    
4 torben 1629 '''
5     Todic plugin for XBMC
6 torben 3246 Version 1.7.3
7 torben 1629 '''
8    
9     import sys
10 torben 1648 import os
11 torben 1629
12 torben 1648
13 torben 1629 import xbmc
14     import xbmcaddon
15     import xbmcgui
16     import xbmcplugin
17     import urllib
18 torben 1678 import urllib2
19 torben 1629
20 torben 2601 # import pprint
21 torben 2595
22 torben 1678 from xml.dom.minidom import parseString
23 torben 3142 from time import time
24 torben 1678
25 torben 1629 __addon__ = xbmcaddon.Addon(id='plugin.video.todic')
26     __key__ = __addon__.getSetting('xbmckey').lower()
27 torben 3208 __entrypoint__ = __addon__.getSetting('entrypoint').lower()
28 torben 3037 __backend__ = "https://todic.dk/xbmc.php?xbmckey=" + __key__
29 torben 3208
30     if __entrypoint__ == "alternative":
31 torben 3245 __backend__ = "https://alt.todic.dk/xbmc.php?xbmckey=" + __key__
32 torben 3208
33     if __entrypoint__ == "testing":
34 torben 3245 __backend__ = "https://todic.dk/xbmc-beta.php?xbmckey=" + __key__
35    
36 torben 3246 print( "[Todic] entrypoint: " + __entrypoint__ )
37     print( "[Todic] backend: " + __backend__ )
38 torben 3208
39    
40 torben 2594 fanartImage = os.path.join(__addon__.getAddonInfo('path'), 'movie_bg_blur.jpg')
41 torben 2601 datapath = xbmc.translatePath(
42     'special://profile/addon_data/plugin.video.todic/')
43 torben 1629
44 torben 2592 ADDON_PATH = __addon__.getAddonInfo('path')
45 torben 2601 SkinMasterPath = os.path.join(ADDON_PATH, 'skins') + '/'
46 torben 2592 MySkinPath = (os.path.join(SkinMasterPath, '720p')) + '/'
47     MySkin = 'main.xml'
48 torben 1676
49 torben 2592
50     class TodicMovieDialog(xbmcgui.WindowXMLDialog):
51    
52 torben 2601 def __new__(cls):
53     return super(TodicMovieDialog, cls).__new__(cls, "main.xml", ADDON_PATH)
54 torben 2592
55 torben 2601 def __init__(self):
56     super(TodicMovieDialog, self).__init__()
57 torben 3147 self.position = 0
58 torben 2592
59 torben 2601 def onClick(self, controlId):
60 torben 3246 print( "[Todic] MovieDialog OnClick: " + str(controlId) )
61 torben 2592
62 torben 2601 if (controlId == 50):
63     self.close()
64 torben 3147 play_real_video(self.url, self.name, 0)
65 torben 2592
66 torben 3147 if (controlId == 51):
67     self.close()
68     play_real_video(self.url, self.name, self.position)
69    
70 torben 2601 if (controlId == 98):
71     self.close()
72 torben 2592
73 torben 2601 def onInit(self):
74 torben 2592
75 torben 3246 print( "[Todic] MovieDialog onInit" )
76 torben 2601 self.getControl(1).setLabel(self.name)
77     self.getControl(2).setLabel(self.moviegroups)
78     self.getControl(3).setLabel(self.description)
79     self.getControl(10).setLabel(self.playlength)
80     self.getControl(11).setLabel(self.codecdetails)
81 torben 2596
82 torben 3147 if (self.position > 0):
83     self.getControl(51).setVisible(True)
84     self.getControl(50).setPosition(100, 570)
85     self.getControl(51).setPosition(450, 570)
86     self.getControl(50).controlLeft( self.getControl(51) )
87     self.getControl(50).controlRight( self.getControl(51) )
88     else:
89     self.getControl(51).setVisible(False)
90 torben 2596
91 torben 3147 #orig_img_width = self.getControl(40).getWidth()
92     #self.starwidth = (float(self.imdbrating) / 10.0) * orig_img_width
93     #self.getControl(40).setWidth(int(self.starwidth))
94    
95 torben 3152 def setDetailsDoc(self, detailsDoc):
96 torben 3246 print( "[Todic] MovieDialog setDetailsDoc:")
97 torben 3152 self.imdbrating = getText(detailsDoc.getElementsByTagName("imdbrating"))
98     self.moviegroups = getText(detailsDoc.getElementsByTagName("moviegroups"))
99     self.playlength = getText(detailsDoc.getElementsByTagName("playlength"))
100     self.codecdetails = getText(detailsDoc.getElementsByTagName("codecdetails"))
101     self.position = int( getText(detailsDoc.getElementsByTagName("position")) )
102 torben 2592
103 torben 3153 def setUrl(self, url):
104     self.url = url
105 torben 3147
106 torben 2601 def setName(self, name):
107     self.name = name
108 torben 2595
109 torben 2601 def setDescription(self, description):
110     self.description = description
111 torben 2595
112 torben 2596
113 torben 2601 class TodicPlayer(xbmc.Player):
114 torben 2596
115 torben 2601 def __init__(self, *args, **kwargs):
116     # xbmc.Player.__init__(selv,*args,**kwargs)
117 torben 3163 xbmc.Player.__init__(self)
118 torben 2601 self.stopped = False
119     self.started = False
120 torben 3142 self.playingPosition = 0.0
121     self.lastReport = 0
122 torben 3246 print( "[TodicPlayer] init")
123 torben 2592
124 torben 2601 def onPlayBackStarted(self):
125     self.started = True
126 torben 3246 print( "[TodicPlayer] : started")
127 torben 2592
128 torben 3142 #When user presses stop, we report back the the position registered in the last call to self.tick()
129 torben 2601 def onPlayBackStopped(self):
130     self.stopped = True
131 torben 3246 print( "[TodicPlayer] : stopped")
132 torben 3149 self.reportPlaytime("stopped")
133 torben 2592
134 torben 3157 def onPlayBackPaused(self):
135 torben 3246 print( "[TodicPlayer] : paused")
136 torben 3157 self.reportPlaytime("paused")
137 torben 3142
138 torben 3157 def onPlayBackResumed(self):
139 torben 3246 print( "[TodicPlayer] : resumed")
140 torben 3157 self.reportPlaytime("resumed")
141 torben 3152
142 torben 3157
143 torben 2601 def onPlayBackEnded(self):
144     self.stopped = True
145 torben 3246 print( "[TodicPlayer] : ended")
146 torben 3149 self.reportPlaytime("ended")
147 torben 1676
148 torben 3142 def tick(self):
149 torben 3157 #print "[Todic] Tick: " + str( self.isPlaying() )
150 torben 3144 if ( self.isPlaying() ):
151 torben 3245 tmpTime = self.getTime()
152 torben 3147
153 torben 3244 #only report time if it has changed in the mean time
154     if tmpTime != self.playingPosition:
155     self.playingPosition = tmpTime
156     now = time()
157     #print "[Todic] tick " + str(now) + " " + str(self.lastReport) + " : " +str(now - self.lastReport)
158     if ( (now - self.lastReport) > 60.0):
159     self.lastReport = now
160     self.reportPlaytime("playing")
161    
162 torben 3149 def reportPlaytime(self, subaction):
163 torben 3151 if (self.playingPosition > 60):
164     url = __backend__ + "&action=playbacktime&subaction=" + subaction + "&time=" + str( self.playingPosition )
165 torben 3246 print( "[Todic] reportPlaytime:" + url)
166 torben 3151 open_url_safe(url)
167    
168 torben 3142
169    
170 torben 2601 def getText2(nodelist):
171     rc = []
172     for node in nodelist:
173     if node.nodeType == node.TEXT_NODE:
174     rc.append(node.data)
175     else:
176     rc.append(getText(node.childNodes))
177     return ''.join(rc)
178 torben 1676
179    
180 torben 1678 def getText(nodelist):
181 torben 2601 if nodelist.length == 0:
182     return ''
183     else:
184     if nodelist[0].childNodes.length == 0:
185     return ''
186     else:
187     return nodelist[0].childNodes[0].nodeValue
188 torben 1676
189 torben 2601
190 torben 3143
191 torben 1914 def SaveFile(path, data):
192 torben 2601 file = open(path, 'w')
193     file.write(data)
194     file.close()
195 torben 1678
196 torben 1914
197 torben 3143
198 torben 1629 def open_url(url):
199 torben 2601 req = urllib2.Request(url)
200     content = urllib2.urlopen(req)
201     data = content.read()
202     content.close()
203     return data
204 torben 1629
205 torben 2601
206 torben 3143 # wraps open url in a catch-all exception handler
207     # usefull for periodic back-reporting that should not interrupt the program flow
208     def open_url_safe(url):
209     try:
210     return open_url(url)
211     except:
212 torben 3246 print( "[Todic] Some error during open_url call to ", url)
213 torben 3143
214    
215    
216 torben 1629 def rootMenu():
217 torben 1648
218 torben 2601 msg = open_url(__backend__ + "&action=messages")
219     msg = msg.strip()
220 torben 1799
221 torben 2601 if msg != "":
222     dialog = xbmcgui.Dialog()
223     dialog.ok('XBMC Todic', msg)
224 torben 1799
225 torben 2601 buildList(__backend__, "", False) # call default list
226 torben 1631
227 torben 2601 # Adde xtra items to root menu
228     listitem = xbmcgui.ListItem(
229 torben 3155 label="Søg Film ...", iconImage='DefaultFolder.png', thumbnailImage='DefaultFolder.png')
230 torben 2601 listitem.setProperty('Fanart_Image', fanartImage)
231 torben 1648
232 torben 2601 u = sys.argv[0] + "?mode=10&name="
233 torben 2602 xbmcplugin.addDirectoryItem(
234 torben 2601 handle=int(sys.argv[1]), url=u, listitem=listitem, isFolder=True)
235 torben 1631
236 torben 2601 # add search series
237     listitem = xbmcgui.ListItem(
238     label="Søg Serier ...", iconImage='DefaultFolder.png', thumbnailImage='DefaultFolder.png')
239     listitem.setProperty('Fanart_Image', fanartImage)
240 torben 2097
241 torben 2601 u = sys.argv[0] + "?mode=11&name="
242 torben 2602 xbmcplugin.addDirectoryItem(
243 torben 2601 handle=int(sys.argv[1]), url=u, listitem=listitem, isFolder=True)
244 torben 2097
245 torben 2601 xbmcplugin.endOfDirectory(int(sys.argv[1]))
246 torben 1629
247    
248 torben 2601 def buildList(url, title, endlist=True):
249 torben 3246 print( '[Todic]:' + str(url) )
250 torben 1678
251 torben 2601 link = open_url(url)
252     doc = parseString(link)
253     ty = doc.getElementsByTagName("meta")[0].getAttribute("type")
254 torben 3246 print( '[Todic]' + str(ty))
255 torben 1646
256 torben 2601 if ty == 'clipList':
257     mode = '50'
258     folder = False
259     else:
260     mode = '1'
261     folder = True
262 torben 1646
263 torben 2601 entries = doc.getElementsByTagName("entry")
264     l = len(entries)
265 torben 3159
266 torben 2601 for entry in entries:
267     name = getText(entry.getElementsByTagName("title"))
268     url = getText(entry.getElementsByTagName("url"))
269     thumb = getText(entry.getElementsByTagName("cover"))
270     playcount = getText(entry.getElementsByTagName("playcount"))
271 torben 1829
272 torben 3148
273 torben 2601 if playcount == '':
274     playcount = '0'
275     playcount = int(playcount)
276 torben 1647
277 torben 2601 # print "name:" + name
278 torben 1678 # print "url:" + url
279     # print "thumb:" + thumb
280 torben 2601 listitem = xbmcgui.ListItem(
281     label=name, label2='test', iconImage='DefaultFolder.png', thumbnailImage=thumb)
282     listitem.setProperty('Fanart_Image', fanartImage)
283 torben 3249 listitem.addContextMenuItems([('Refresh', 'Container.Refresh')])
284    
285 torben 2601 if mode == '50':
286     infoLabels = {}
287     infoLabels['title'] = name
288     infoLabels['playcount'] = playcount
289     listitem.setInfo('video', infoLabels)
290 torben 1678
291 torben 2601 name = name.encode('UTF-8')
292 torben 1678
293 torben 2601 u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote(
294 torben 3159 name) + "&url=" + urllib.quote(url)
295 torben 2602 xbmcplugin.addDirectoryItem(
296 torben 2601 handle=int(sys.argv[1]), url=u, listitem=listitem, isFolder=folder, totalItems=l)
297 torben 1648
298 torben 2601 if (endlist == True):
299     xbmcplugin.endOfDirectory(int(sys.argv[1]))
300 torben 1923
301    
302 torben 3159 def play_video(url, name):
303     description = ""
304 torben 3158 playPosition = 0
305     savedPosition = 0
306     try:
307     param1 = parse_parameter_string(url)
308     clipkey = param1["clipkey"]
309 torben 3152
310 torben 3246 print( "[Todic] ClipKey:" + clipkey)
311 torben 3158 detailurl = __backend__ + "&action=clipdetails&clipkey=" + clipkey
312 torben 3246 print( "[Todic] detailURL = " + detailurl)
313 torben 3152
314 torben 3158 xml = open_url(detailurl)
315 torben 3152
316 torben 3158 clipDetailsDoc = parseString(xml)
317     savedPosition = int( getText(clipDetailsDoc.getElementsByTagName("position")) )
318 torben 3159 description = getText(clipDetailsDoc.getElementsByTagName("description"))
319 torben 3158 except:
320 torben 3246 print( "[Todic] Unexpected error:", sys.exc_info()[0] )
321 torben 3152
322 torben 2601 if (description == None or description == ""):
323 torben 3152 if (savedPosition > 0):
324     dialog = xbmcgui.Dialog()
325     #yes / true -afspil fra position
326 torben 3155 answer = dialog.yesno(heading='Todic', line1='Afspil fra sidste position', nolabel='Fra start', yeslabel='Fortsæt')
327 torben 3152 if (answer == True):
328     playPosition = savedPosition
329    
330     play_real_video(url, name, playPosition)
331    
332 torben 2601 else:
333     d = TodicMovieDialog()
334 torben 3152 d.setDetailsDoc(clipDetailsDoc)
335 torben 2601 d.setName(name)
336 torben 3153 d.setUrl(url)
337 torben 2601 d.setDescription(description)
338 torben 1629
339 torben 2601 d.doModal()
340 torben 1629
341    
342 torben 3147 def play_real_video(url, name, position):
343 torben 2601 xml = open_url(url)
344 torben 3246 print( '[Todic] url: ' + str(url) )
345     print( '[Todic] xml: ' + xml )
346     print( '[Todic] pos: ' + str(position) )
347 torben 1678
348 torben 2601 doc = parseString(xml)
349     url = getText(doc.getElementsByTagName("url"))
350 torben 1678
351 torben 2601 subtitleurl = getText(doc.getElementsByTagName("subtitles"))
352 torben 1914
353 torben 1917
354 torben 3246 print( '[Todic] subs: ' + str(subtitleurl) )
355 torben 1914
356 torben 2601 image = xbmc.getInfoImage('ListItem.Thumb')
357     listitem = xbmcgui.ListItem(
358     label=name, iconImage='DefaultVideo.png', thumbnailImage=image)
359     listitem.setInfo(type="Video", infoLabels={"Title": name})
360 torben 3147 listitem.setProperty('ResumeTime', '300')
361     listitem.setProperty('TotalTime', '3000')
362 torben 1914
363 torben 3250 if len(subtitleurl) > 0:
364     listitem.setSubtitles([subtitleurl])
365    
366 torben 3165 player = TodicPlayer()
367 torben 2601 player.play(str(url), listitem)
368 torben 1914
369 torben 2601 # kan ikke loade subtitles hvis foerend playeren koerer
370     count = 0
371     while not xbmc.Player().isPlaying():
372 torben 3146 xbmc.sleep(250)
373 torben 2601 count += 1
374     if count > 10:
375     break
376 torben 1629
377 torben 3147
378    
379 torben 2601 if xbmc.Player().isPlaying():
380 torben 1914
381 torben 3147 if (position > 0):
382     while (player.getTotalTime() == 0.0): #Vent indtil vi har beregnet hvor langt klippet er
383     xbmc.sleep(250)
384 torben 3142
385 torben 3246 print( "[Todic] totalTime " + str( player.getTotalTime() ))
386 torben 3147 player.seekTime(position)
387 torben 3142
388 torben 1676
389 torben 3147 #Holder python kørernde indtil at det bliver bedt om at stoppe
390     while (not xbmc.abortRequested):
391     player.tick()
392     xbmc.sleep(500)
393 torben 1676
394 torben 3147
395    
396 torben 1631 def search():
397 torben 2601 search = getUserInput("Todic Søgning")
398 torben 1629
399 torben 2601 if (search != None and search != ""):
400     url = __backend__ + "&action=search&search=" + \
401     urllib.quote_plus(search)
402 torben 1631
403 torben 3157 # print "[Todic] Search start: " + search
404     # print "[Todic] Search url: " + url
405 torben 1631
406 torben 2601 buildList(url, "søgning")
407 torben 1631
408 torben 2601
409 torben 2097 def searchSeries():
410 torben 2601 search = getUserInput("Todic Serie Søgning")
411 torben 2097
412 torben 2601 if (search != None and search != ""):
413     url = __backend__ + "&action=searchseries&search=" + \
414     urllib.quote_plus(search)
415 torben 2097
416 torben 3157 # print "[Todic] Search start: " + search
417     # print "[Todic] Search url: " + url
418 torben 2097
419 torben 2601 buildList(url, "serie søgning")
420 torben 2097
421 torben 1631
422 torben 2601 #=================================== Tool Box =======================================
423 torben 1631 # shows a more userfriendly notification
424     def showMessage(heading, message):
425 torben 2601 duration = 15 * 1000
426     xbmc.executebuiltin('XBMC.Notification("%s", "%s", %s)' %
427     (heading, message, duration))
428 torben 1631
429    
430     # raise a keyboard for user input
431 torben 2601 def getUserInput(title="Input", default="", hidden=False):
432     result = None
433 torben 1631
434 torben 2601 # Fix for when this functions is called with default=None
435     if not default:
436     default = ""
437 torben 1631
438 torben 2601 keyboard = xbmc.Keyboard(default, title)
439     keyboard.setHiddenInput(hidden)
440     keyboard.doModal()
441 torben 1631
442 torben 2601 if keyboard.isConfirmed():
443     result = keyboard.getText()
444    
445     return result
446    
447    
448 torben 1629 def get_params():
449 torben 2601 return parse_parameter_string(sys.argv[2])
450 torben 2595
451 torben 1629
452 torben 2601 def parse_parameter_string(paramstring):
453     param = []
454     if len(paramstring) >= 2:
455     params = paramstring
456     cleanedparams = params.replace('?', '')
457     if (params[len(params) - 1] == '/'):
458     params = params[0:len(params) - 2]
459     pairsofparams = cleanedparams.split('&')
460     param = {}
461     for i in range(len(pairsofparams)):
462     splitparams = {}
463     splitparams = pairsofparams[i].split('=')
464     if (len(splitparams)) == 2:
465     param[splitparams[0]] = splitparams[1]
466     return param
467 torben 1629
468 torben 2601
469 torben 1629 params = get_params()
470     url = None
471     name = None
472     mode = None
473    
474 torben 3149
475 torben 3148 #print params
476    
477 torben 1629 try:
478 torben 2601 url = urllib.unquote_plus(params["url"])
479 torben 1629 except:
480 torben 2601 pass
481 torben 1629 try:
482 torben 2601 name = urllib.unquote_plus(params["name"])
483 torben 1629 except:
484 torben 2601 pass
485 torben 1629 try:
486 torben 2601 mode = int(params["mode"])
487 torben 1629 except:
488 torben 2601 pass
489 torben 1629
490 torben 3148
491    
492 torben 3147
493     try:
494 torben 2601 open_url("http://todic.dk")
495 torben 2440 except:
496 torben 2601 showMessage("Fejl", "Kunne ikke forbinde til todic.dk")
497     exit()
498 torben 2440
499 torben 2601
500 torben 1814 if url == 'refresh':
501 torben 2601 # xbmc.output("[tvserver] Container.Refresh") #20130418 xbmc.output virker
502     # ikke med XBMC12
503     xbmc.executebuiltin("Container.Refresh")
504 torben 1629
505 torben 2601
506 torben 1814 elif mode == None:
507 torben 2601 # build main menu
508     rootMenu()
509    
510 torben 1629 elif mode == 1:
511 torben 2601 # build list of movie starting letters
512     buildList(url, name)
513 torben 1629
514 torben 1631 elif mode == 10:
515 torben 2601 search()
516 torben 2097
517     elif mode == 11:
518 torben 2601 searchSeries()
519 torben 1631
520 torben 2601
521 torben 1629 elif mode == 50:
522 torben 3159 play_video(url, name)

  ViewVC Help
Powered by ViewVC 1.1.20