From 851e65374b9ab17669641912a8fb726e759c380c Mon Sep 17 00:00:00 2001 From: im85288 Date: Tue, 24 Mar 2015 22:39:19 +0000 Subject: [PATCH] added copying theme music - plus workaround for reported boxset issues --- resources/lib/CreateFiles.py | 31 +++++++++++++++++++++++++++++++ resources/lib/WriteKodiDB.py | 9 ++++++++- 2 files changed, 39 insertions(+), 1 deletion(-) diff --git a/resources/lib/CreateFiles.py b/resources/lib/CreateFiles.py index 01ae09a7..4f7f0224 100644 --- a/resources/lib/CreateFiles.py +++ b/resources/lib/CreateFiles.py @@ -264,6 +264,37 @@ class CreateFiles(): return changes + + def copyThemeMusic(self,item): + downloadUtils = DownloadUtils() + userid = downloadUtils.getUserId() + port = addon.getSetting('port') + host = addon.getSetting('ipaddress') + server = host + ":" + port + item_type=str(item.get("Type")) + + if item_type == "Movie": + itemPath = os.path.join(movieLibrary,item["Id"]) + themeFile = os.path.join(itemPath,"theme.mp3") + if item_type == "Series": + itemPath = os.path.join(tvLibrary,item["Id"]) + themeFile = os.path.join(itemPath,"theme.mp3") + + + if not xbmcvfs.exists(themeFile): + utils.logMsg("MB3 Syncer","creating Theme file " + themeFile,2) + #theme music link + themeMusicUrl = "http://" + server + "/mediabrowser/Items/" + item["Id"] + "/ThemeSongs?format=json" + jsonData = downloadUtils.downloadUrl(themeMusicUrl, suppress=True, popup=0 ) + if(jsonData != ""): + themeMusic = json.loads(jsonData) + if(themeMusic != None and themeMusic["TotalRecordCount"] > 0): + themeItems = themeMusic["Items"] + if themeItems[0] != None: + mediasources = themeItems[0]["MediaSources"] + if mediasources[0]["Container"] == "mp3": + themeUrl = PlayUtils().getPlayUrl(server,themeItems[0]["Id"],themeItems[0]) + xbmcvfs.copy(themeUrl,themeFile) def CleanName(self, name): name = name.replace(":", "-") diff --git a/resources/lib/WriteKodiDB.py b/resources/lib/WriteKodiDB.py index eb96fef0..99be3ad4 100644 --- a/resources/lib/WriteKodiDB.py +++ b/resources/lib/WriteKodiDB.py @@ -683,6 +683,9 @@ class WriteKodiDB(): # create strm file changes |= CreateFiles().createSTRM(item) + #add theme music + CreateFiles().copyThemeMusic(item) + if changes: utils.logMsg("MB3 Sync","Added movie to Kodi Library",item["Id"] + " - " + item["Name"]) @@ -768,6 +771,9 @@ class WriteKodiDB(): #create nfo file changes = CreateFiles().createNFO(item) + #add theme music + CreateFiles().copyThemeMusic(item) + if changes: utils.logMsg("Added TV Show to Kodi Library ",item["Id"] + " - " + item["Name"]) @@ -972,4 +978,5 @@ class WriteKodiDB(): def updateBoxsetToKodiLibrary(self, boxsetmovie, boxset): strSet = boxset["Name"] kodiMovie = ReadKodiDB().getKodiMovie(boxsetmovie["Id"]) - WriteKodiDB().updateProperty(kodiMovie,"set",strSet,"movie",True) \ No newline at end of file + if kodiMovie != None: + WriteKodiDB().updateProperty(kodiMovie,"set",strSet,"movie",True) \ No newline at end of file