소스 검색

playserver now with playlist ability

A 4 년 전
부모
커밋
87679c3fcb
2개의 변경된 파일117개의 추가작업 그리고 65개의 파일을 삭제
  1. 37 0
      src/playserver.py
  2. 80 65
      src/plugin.py

+ 37 - 0
src/playserver.py

@@ -107,6 +107,9 @@ class __PlayServer__(object):
                     if command == "play":
                         __client_socket__.send("HTTP/1.1 200 OK\r\nContent-Type: application/octet-stream\r\nConnection: close\r\n\r\n")
 
+                    elif command == "playlist":
+                        __client_socket__.send("HTTP/1.1 200 OK\r\nContent-Type: audio/x-mpegurl; charset=utf-8\r\nConnection: close\r\n\r\n")
+
                 else:
                     if command == "exit":
                         __client_socket__.send("HTTP/1.1 200 OK\r\nContent-Length: 2\r\nContent-Type: text/plain\r\nConnection: close\r\n\r\nOK")
@@ -115,6 +118,40 @@ class __PlayServer__(object):
                         self._running = False
                         return True
 
+                    elif command == "playlist":
+                        episode_id = params[1]
+
+                        episode_result = __api__.__get__("get/episode", __data__={
+                            "id": episode_id,
+                            "withParents": 1,
+                            "withPlaylist": 30
+                        })
+
+                        if not episode_result:
+                            raise Exception("Fehler beim verarbeiten der Antwort.")
+
+                        item = prepare_movies_to_list([episode_result["data"]["season"]["movie"]])
+                        item = item[0]
+
+                        next_episodes = episode_result["data"].pop("next_episodes")
+                        season = episode_result["data"].pop("season")
+
+                        items = [episode_result["data"]]
+                        items.extend(next_episodes)
+
+                        playlist_content = ""
+                        playlist_content += "#EXTM3U\n"
+
+                        for episode in items:
+                            tagline = unicode("%s" % (episode["title"] if season["title"] == "Default" else ("%s. %s" % (episode["number"], episode["title"]))))
+                            title = "%s" % (unicode(tagline).replace(u"ä", "ae").replace(u"Ä", "Ae").replace(u"ö", "oe").replace(u"Ö", "Oe").replace(u"ü", "ue").replace(",", " "))
+                            playlist_content += "#EXTINF:-1,%s\n" % title
+                            path = "http://127.0.0.1:%s/play/%s/%s.mkv" % (self._port, episode["id"], urllib.quote(title))
+                            playlist_content += "%s\n" % path
+
+                        #__client_socket__.send("HTTP/1.1 200 OK\r\nContent-Type: application/x-mpegURL; charset=utf-8\r\nContent-Length: %s\r\nConnection: close\r\n\r\n%s" % (len(playlist_content), playlist_content))
+                        __client_socket__.send("HTTP/1.1 200 OK\r\nContent-Type: audio/x-mpegurl; charset=utf-8\r\nContent-Length: %s\r\nConnection: close\r\n\r\n%s" % (len(playlist_content), playlist_content))
+
                     elif command == "play":
                         read_settings()
                         check_settings()

+ 80 - 65
src/plugin.py

@@ -340,6 +340,8 @@ def play_episode(episode_id=0, ask_playlist=0):
     @return:
     """
 
+    EXTERNAL_PLAYER = False
+
     show_busy_dialog()
     if episode_id == 0:
         return empty()
@@ -362,7 +364,7 @@ def play_episode(episode_id=0, ask_playlist=0):
     episode_result = __api__.__get__("get/episode", __data__={
         "id": episode_id,
         "withParents": 1,
-        "withPlaylist": 30 if ret else 0
+        "withPlaylist": 30 if ret and not EXTERNAL_PLAYER else 0
     })
 
     if not episode_result:
@@ -370,13 +372,6 @@ def play_episode(episode_id=0, ask_playlist=0):
         PLUGIN.dialog("Fehler beim verarbeiten der Antwort.")
         return empty()
 
-    item = prepare_movies_to_list([episode_result["data"]["season"]["movie"]])
-    item = item[0]
-    item["is_playable"] = True
-
-    playlist = xbmc.PlayList(xbmc.PLAYLIST_VIDEO)
-    playlist.clear()
-
     play_port = None
     try:
         server = __PlayServer__()
@@ -407,72 +402,92 @@ def play_episode(episode_id=0, ask_playlist=0):
 
         raise
 
-    # Main Episode
-    episode = episode_result["data"]
-    li = copy.copy(item)
-    li["properties"] = {
-        "MovieID": unicode(episode["id"])
-    }
+    item = prepare_movies_to_list([episode_result["data"]["season"]["movie"]])
+    item = item[0]
+    item["is_playable"] = True
+
+    playlist = xbmc.PlayList(xbmc.PLAYLIST_VIDEO)
+    playlist.clear()
+
+    if EXTERNAL_PLAYER and ret:
+        output("[PLAY] Will generate playlist")
+
+        path = "http://127.0.0.1:%s/playlist/%s/Playlist.m3u" % (play_port, episode_id)
+
+        li = copy.copy(item)
+        li = PLUGIN._listitemify(li).as_xbmc_listitem()
+        playlist.add(path, li)
 
-    if episode["title"] == "Mainepisode":
-        li["info"]["tagline"] = ""
     else:
-        tagline = unicode("%s - %s" % (episode_result["data"]["season"]["movie"]["title"], episode["title"] if episode_result["data"]["season"]["title"] == "Default" else (episode_result["data"]["season"]["title"] + " - %s. %s" % (episode["number"], episode["title"]))))
 
-        if SWITCH_TAGLINE:
-            title = li["label"]
-            li["label"] = tagline
-            li["info"]["title"] = tagline
-            li["info"]["tagline"] = title
+        # Main Episode
+        episode = episode_result["data"]
+        li = copy.copy(item)
+        li["properties"] = {
+            "MovieID": unicode(episode["id"])
+        }
+
+        if episode["title"] == "Mainepisode":
+            li["info"]["tagline"] = ""
         else:
-            li["info"]["tagline"] = tagline
-
-    li["path"] = path = "http://127.0.0.1:%s/play/%s/%s.mkv" % (play_port, episode["id"], urllib.quote(li["label"]))
-    li = PLUGIN._listitemify(li).as_xbmc_listitem()
-    playlist.add(path, li)
-
-    # Playlist episodes
-    if "next_episodes" in episode_result["data"]:
-        for episode in episode_result["data"]["next_episodes"]:
-            li = copy.copy(item)
-            li["properties"] = {
-                "MovieID": unicode(episode["id"])
-            }
-
-            if episode["title"] == "Mainepisode":
-                li["info"]["tagline"] = ""
+            tagline = unicode("%s - %s" % (episode_result["data"]["season"]["movie"]["title"], episode["title"] if episode_result["data"]["season"]["title"] == "Default" else (episode_result["data"]["season"]["title"] + " - %s. %s" % (episode["number"], episode["title"]))))
+
+            if SWITCH_TAGLINE:
+                title = li["label"]
+                li["label"] = tagline
+                li["info"]["title"] = tagline
+                li["info"]["tagline"] = title
             else:
-                tagline = unicode("%s - %s" % (episode_result["data"]["season"]["movie"]["title"], episode["title"] if episode_result["data"]["season"]["title"] == "Default" else (episode_result["data"]["season"]["title"] + " - %s. %s" % (episode["number"], episode["title"]))))
+                li["info"]["tagline"] = tagline
+
+        tit = unicode("%s" % (episode_result["data"]["season"]["title"] if episode_result["data"]["season"]["title"] == "Default" else ("%s. %s" % (episode["number"], episode["title"]))))
+        li["path"] = path = "http://127.0.0.1:%s/play/%s/%s.mkv" % (play_port, episode["id"], urllib.quote(tit))
+        li = PLUGIN._listitemify(li).as_xbmc_listitem()
+        playlist.add(path, li)
+
+        # Playlist episodes
+        if "next_episodes" in episode_result["data"]:
+            for episode in episode_result["data"]["next_episodes"]:
+                li = copy.copy(item)
+                li["properties"] = {
+                    "MovieID": unicode(episode["id"])
+                }
 
-                if SWITCH_TAGLINE:
-                    title = li["label"]
-                    li["label"] = tagline
-                    li["info"]["title"] = tagline
-                    li["info"]["tagline"] = title
+                if episode["title"] == "Mainepisode":
+                    li["info"]["tagline"] = ""
                 else:
-                    li["info"]["tagline"] = tagline
-
-            li["path"] = path = "http://127.0.0.1:%s/play/%s/%s.mkv" % (play_port, episode["id"], urllib.quote(li["label"]))
-            li = PLUGIN._listitemify(li).as_xbmc_listitem()
-            playlist.add(path, li)
-
-    #ifdef DEBUG
-    for idx in range(playlist.size()):
-        output("[PLAY] %s - Item %s" % (idx, playlist[idx].getPath()))
-    #endif
-
-    first = playlist[0]
-    if first:
-        episode_id = first.getProperty("MovieID")
-        offset = read_watchtime(episode_id)
-        if offset > 0:
-            ret = PLUGIN.yesno("Soll das Video bei Position %s fortgesetzt werden?" % format_seconds_to_hhmmss(offset))
-            if ret == 0:
-                save_watchtime(offset, 0)
-                offset = 0
+                    tagline = unicode("%s - %s" % (episode_result["data"]["season"]["movie"]["title"], episode["title"] if episode_result["data"]["season"]["title"] == "Default" else (episode_result["data"]["season"]["title"] + " - %s. %s" % (episode["number"], episode["title"]))))
 
+                    if SWITCH_TAGLINE:
+                        title = li["label"]
+                        li["label"] = tagline
+                        li["info"]["title"] = tagline
+                        li["info"]["tagline"] = title
+                    else:
+                        li["info"]["tagline"] = tagline
+
+                tit = unicode("%s" % (episode_result["data"]["season"]["title"] if episode_result["data"]["season"]["title"] == "Default" else ("%s. %s" % (episode["number"], episode["title"]))))
+                li["path"] = path = "http://127.0.0.1:%s/play/%s/%s.mkv" % (play_port, episode["id"], urllib.quote(tit))
+                li = PLUGIN._listitemify(li).as_xbmc_listitem()
+                playlist.add(path, li)
+
+        #ifdef DEBUG
+        for idx in range(playlist.size()):
+            output("[PLAY] %s - Item %s" % (idx, playlist[idx].getPath()))
+        #endif
+
+        first = playlist[0]
+        if first:
+            episode_id = first.getProperty("MovieID")
+            offset = read_watchtime(episode_id)
             if offset > 0:
-                first.setProperty("StartOffset", "%s" % offset)
+                ret = PLUGIN.yesno("Soll das Video bei Position %s fortgesetzt werden?" % format_seconds_to_hhmmss(offset))
+                if ret == 0:
+                    save_watchtime(offset, 0)
+                    offset = 0
+
+                if offset > 0:
+                    first.setProperty("StartOffset", "%s" % offset)
 
     player = xbmc.Player()
     player.play(playlist)