################################################################################################# # In Progress Updater ################################################################################################# import xbmc import xbmcgui import xbmcaddon import json import threading from datetime import datetime import urllib from DownloadUtils import DownloadUtils _MODE_BASICPLAY=12 #define our global download utils downloadUtils = DownloadUtils() class InProgressUpdaterThread(threading.Thread): logLevel = 0 def __init__(self, *args): addonSettings = xbmcaddon.Addon(id='plugin.video.xbmb3c') level = addonSettings.getSetting('logLevel') self.logLevel = 0 if(level != None): self.logLevel = int(level) xbmc.log("XBMB3C InProgressUpdaterThread -> Log Level:" + str(self.logLevel)) threading.Thread.__init__(self, *args) def logMsg(self, msg, level = 1): if(self.logLevel >= level): xbmc.log("XBMB3C InProgressUpdaterThread -> " + msg) def run(self): self.logMsg("Started") self.updateInProgress() lastRun = datetime.today() updateInterval = 300 while (xbmc.abortRequested == False): td = datetime.today() - lastRun secTotal = td.seconds if(secTotal > updateInterval): self.updateInProgress() lastRun = datetime.today() xbmc.sleep(3000) self.logMsg("Exited") def updateInProgress(self): self.logMsg("updateInProgress Called") addonSettings = xbmcaddon.Addon(id='plugin.video.xbmb3c') mb3Host = addonSettings.getSetting('ipaddress') mb3Port = addonSettings.getSetting('port') userName = addonSettings.getSetting('username') userid = downloadUtils.getUserId() self.logMsg("InProgress UserName : " + userName + " UserID : " + userid) self.logMsg("Updating In Progress Movie List") recentUrl = "http://" + mb3Host + ":" + mb3Port + "/mediabrowser/Users/" + userid + "/Items?Limit=30&Recursive=true&SortBy=DatePlayed&SortOrder=Descending&Fields=Path,Genres,MediaStreams,Overview,CriticRatingSummary&Filters=IsResumable&IncludeItemTypes=Movie&format=json" jsonData = downloadUtils.downloadUrl(recentUrl, suppress=False, popup=1 ) result = json.loads(jsonData) result = result.get("Items") if(result == None): result = [] WINDOW = xbmcgui.Window( 10000 ) item_count = 1 for item in result: title = "Missing Title" if(item.get("Name") != None): title = item.get("Name").encode('utf-8') rating = item.get("CommunityRating") criticrating = item.get("CriticRating") officialrating = item.get("OfficialRating") criticratingsummary = "" if(item.get("CriticRatingSummary") != None): criticratingsummary = item.get("CriticRatingSummary").encode('utf-8') plot = item.get("Overview") if plot == None: plot='' plot=plot.encode('utf-8') year = item.get("ProductionYear") if(item.get("RunTimeTicks") != None): runtime = str(int(item.get("RunTimeTicks"))/(10000000*60)) else: runtime = "0" userData = item.get("UserData") if(userData != None): reasonableTicks = int(userData.get("PlaybackPositionTicks")) / 1000 seekTime = reasonableTicks / 10000 duration = float(runtime) resume = float(seekTime) / 60.0 if (duration == 0): percentage=0 else: percentage = (resume / duration) * 100.0 perasint = int(percentage) title = str(perasint) + "% " + title item_id = item.get("Id") thumbnail = downloadUtils.getArtwork(item, "Primary2") logo = downloadUtils.getArtwork(item, "Logo") fanart = downloadUtils.getArtwork(item, "Backdrop") medium_fanart = downloadUtils.getArtwork(item, "Backdrop3") if item.get("ImageTags").get("Thumb") != None: realthumbnail = downloadUtils.getArtwork(item, "Thumb3") else: realthumbnail = fanart url = mb3Host + ":" + mb3Port + ',;' + item_id playUrl = "plugin://plugin.video.xbmb3c/?url=" + url + '&mode=' + str(_MODE_BASICPLAY) playUrl = playUrl.replace("\\\\","smb://") playUrl = playUrl.replace("\\","/") self.logMsg("InProgressMovieMB3." + str(item_count) + ".Title = " + title, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Thumb = " + realthumbnail, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Path = " + playUrl, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Art(fanart) = " + fanart, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Art(clearlogo) = " + logo, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Art(poster) = " + thumbnail, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Rating = " + str(rating), level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".CriticRating = " + str(criticrating), level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".CriticRatingSummary = " + criticratingsummary, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Plot = " + plot, level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Year = " + str(year), level=2) self.logMsg("InProgressMovieMB3." + str(item_count) + ".Runtime = " + str(runtime), level=2) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Title", title) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Thumb", realthumbnail) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Path", playUrl) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Art(fanart)", fanart) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Art(medium_fanart)", medium_fanart) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Art(clearlogo)", logo) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Art(poster)", thumbnail) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Rating", str(rating)) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Mpaa", str(officialrating)) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".CriticRating", str(criticrating)) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".CriticRatingSummary", criticratingsummary) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Plot", plot) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Year", str(year)) WINDOW.setProperty("InProgressMovieMB3." + str(item_count) + ".Runtime", str(runtime)) WINDOW.setProperty("InProgressMovieMB3.Enabled", "true") item_count = item_count + 1 # blank any not available for x in range(item_count, 11): WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Title", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Thumb", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Path", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Art(fanart)", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Art(clearlogo)", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Art(poster)", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Rating", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".CriticRating", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".CriticRatingSummary", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Plot", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Year", "") WINDOW.setProperty("InProgressMovieMB3." + str(x) + ".Runtime", "") #Updating Recent TV Show List self.logMsg("Updating In Progress Episode List") recentUrl = "http://" + mb3Host + ":" + mb3Port + "/mediabrowser/Users/" + userid + "/Items?Limit=30&Recursive=true&SortBy=DatePlayed&SortOrder=Descending&Fields=Path,Genres,MediaStreams,Overview,CriticRatingSummary&Filters=IsResumable&IncludeItemTypes=Episode&format=json" jsonData = downloadUtils.downloadUrl(recentUrl, suppress=False, popup=1 ) result = json.loads(jsonData) result = result.get("Items") if(result == None): result = [] item_count = 1 for item in result: title = "Missing Title" if(item.get("Name") != None): title = item.get("Name").encode('utf-8') seriesName = "Missing Name" if(item.get("SeriesName") != None): seriesName = item.get("SeriesName").encode('utf-8') eppNumber = "X" tempEpisodeNumber = "00" if(item.get("IndexNumber") != None): eppNumber = item.get("IndexNumber") if eppNumber < 10: tempEpisodeNumber = "0" + str(eppNumber) else: tempEpisodeNumber = str(eppNumber) seasonNumber = item.get("ParentIndexNumber") if seasonNumber < 10: tempSeasonNumber = "0" + str(seasonNumber) else: tempSeasonNumber = str(seasonNumber) rating = str(item.get("CommunityRating")) plot = item.get("Overview") if plot == None: plot='' plot=plot.encode('utf-8') if(item.get("RunTimeTicks") != None): runtime = str(int(item.get("RunTimeTicks"))/(10000000*60)) else: runtime = "0" userData = item.get("UserData") if(userData != None): reasonableTicks = int(userData.get("PlaybackPositionTicks")) / 1000 seekTime = reasonableTicks / 10000 duration = float(runtime) resume = float(seekTime) / 60.0 if (duration == 0): percentage=0 else: percentage = (resume / duration) * 100.0 perasint = int(percentage) title = str(perasint) + "% " + title item_id = item.get("Id") if item.get("Type") == "Episode" or item.get("Type") == "Season": series_id = item.get("SeriesId") poster = downloadUtils.getArtwork(item, "SeriesPrimary") thumbnail = downloadUtils.getArtwork(item, "Primary") logo = downloadUtils.getArtwork(item, "Logo") fanart = downloadUtils.getArtwork(item, "Backdrop") medium_fanart = downloadUtils.getArtwork(item, "Backdrop3") banner = downloadUtils.getArtwork(item, "Banner") if item.get("SeriesThumbImageTag") != None: seriesthumbnail = downloadUtils.getArtwork(item, "Thumb3") else: seriesthumbnail = fanart url = mb3Host + ":" + mb3Port + ',;' + item_id playUrl = "plugin://plugin.video.xbmb3c/?url=" + url + '&mode=' + str(_MODE_BASICPLAY) playUrl = playUrl.replace("\\\\","smb://") playUrl = playUrl.replace("\\","/") self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".EpisodeTitle = " + title, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".ShowTitle = " + seriesName, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".EpisodeNo = " + tempEpisodeNumber, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".SeasonNo = " + tempSeasonNumber, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Thumb = " + thumbnail, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Path = " + playUrl, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Rating = " + rating, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.fanart) = " + fanart, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.clearlogo) = " + logo, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.banner) = " + banner, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.poster) = " + poster, level=2) self.logMsg("InProgresstEpisodeMB3." + str(item_count) + ".Plot = " + plot, level=2) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".EpisodeTitle", title) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".ShowTitle", seriesName) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".EpisodeNo", tempEpisodeNumber) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".SeasonNo", tempSeasonNumber) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Thumb", thumbnail) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".SeriesThumb", seriesthumbnail) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Path", playUrl) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Rating", rating) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.fanart)", fanart) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.medium_fanart)", medium_fanart) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.clearlogo)", logo) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.banner)", banner) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Art(tvshow.poster)", poster) WINDOW.setProperty("InProgresstEpisodeMB3." + str(item_count) + ".Plot", plot) WINDOW.setProperty("InProgresstEpisodeMB3.Enabled", "true") item_count = item_count + 1 # blank any not available for x in range(item_count, 11): WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".EpisodeTitle", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".ShowTitle", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".EpisodeNo", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".SeasonNo", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Thumb", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Path", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Rating", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Art(tvshow.fanart)", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Art(tvshow.clearlogo)", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Art(tvshow.banner)", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Art(tvshow.poster)", "") WINDOW.setProperty("InProgresstEpisodeMB3." + str(x) + ".Plot", "")