mirror of
https://github.com/jellyfin/jellyfin-kodi.git
synced 2025-01-23 16:36:12 +00:00
add back in the PlayUtils for the WebSocket actions
This commit is contained in:
parent
06052426e2
commit
c40e01043d
2 changed files with 133 additions and 28 deletions
|
@ -11,10 +11,10 @@ import inspect
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from DownloadUtils import DownloadUtils
|
from DownloadUtils import DownloadUtils
|
||||||
downloadUtils = DownloadUtils()
|
|
||||||
from PlayUtils import PlayUtils
|
from PlayUtils import PlayUtils
|
||||||
from ReadKodiDB import ReadKodiDB
|
from ReadKodiDB import ReadKodiDB
|
||||||
from ReadEmbyDB import ReadEmbyDB
|
from ReadEmbyDB import ReadEmbyDB
|
||||||
|
import Utils as utils
|
||||||
from API import API
|
from API import API
|
||||||
import Utils as utils
|
import Utils as utils
|
||||||
import os
|
import os
|
||||||
|
@ -24,26 +24,25 @@ addon = xbmcaddon.Addon(id='plugin.video.emby')
|
||||||
addondir = xbmc.translatePath(addon.getAddonInfo('profile'))
|
addondir = xbmc.translatePath(addon.getAddonInfo('profile'))
|
||||||
|
|
||||||
WINDOW = xbmcgui.Window( 10000 )
|
WINDOW = xbmcgui.Window( 10000 )
|
||||||
port = addon.getSetting('port')
|
|
||||||
host = addon.getSetting('ipaddress')
|
|
||||||
server = host + ":" + port
|
|
||||||
userid = downloadUtils.getUserId()
|
|
||||||
|
|
||||||
|
|
||||||
class PlaybackUtils():
|
class PlaybackUtils():
|
||||||
|
|
||||||
settings = None
|
settings = None
|
||||||
language = addon.getLocalizedString
|
language = addon.getLocalizedString
|
||||||
logLevel = 0
|
logLevel = 0
|
||||||
|
downloadUtils = DownloadUtils()
|
||||||
|
|
||||||
def __init__(self, *args):
|
def __init__(self, *args):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
def PLAY(self, id):
|
def PLAY(self, id):
|
||||||
|
|
||||||
jsonData = downloadUtils.downloadUrl("http://" + server + "/mediabrowser/Users/" + userid + "/Items/" + id + "?format=json&ImageTypeLimit=1", suppress=False, popup=1 )
|
port = addon.getSetting('port')
|
||||||
|
host = addon.getSetting('ipaddress')
|
||||||
|
server = host + ":" + port
|
||||||
|
|
||||||
|
userid = self.downloadUtils.getUserId()
|
||||||
|
jsonData = self.downloadUtils.downloadUrl("http://" + server + "/mediabrowser/Users/" + userid + "/Items/" + id + "?format=json&ImageTypeLimit=1", suppress=False, popup=1 )
|
||||||
result = json.loads(jsonData)
|
result = json.loads(jsonData)
|
||||||
|
|
||||||
userData = result.get("UserData")
|
userData = result.get("UserData")
|
||||||
|
@ -101,7 +100,6 @@ class PlaybackUtils():
|
||||||
display_list = [ self.language(30106) + ' ' + displayTime, self.language(30107)]
|
display_list = [ self.language(30106) + ' ' + displayTime, self.language(30107)]
|
||||||
resumeScreen = xbmcgui.Dialog()
|
resumeScreen = xbmcgui.Dialog()
|
||||||
resume_result = resumeScreen.select(self.language(30105), display_list)
|
resume_result = resumeScreen.select(self.language(30105), display_list)
|
||||||
xbmc.log("RESUME_QUESTION : " + str(resume_result))
|
|
||||||
if resume_result == 0:
|
if resume_result == 0:
|
||||||
WINDOW.setProperty(playurl+"seektime", str(seekTime))
|
WINDOW.setProperty(playurl+"seektime", str(seekTime))
|
||||||
else:
|
else:
|
||||||
|
@ -138,7 +136,7 @@ class PlaybackUtils():
|
||||||
xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, listItem)
|
xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, listItem)
|
||||||
else:
|
else:
|
||||||
xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, listItem)
|
xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, listItem)
|
||||||
#xbmc.Player().play(playurl,listItem)
|
xbmc.Player().play(playurl,listItem)
|
||||||
|
|
||||||
def setArt(self, list,name,path):
|
def setArt(self, list,name,path):
|
||||||
if name=='thumb' or name=='fanart_image' or name=='small_poster' or name=='tiny_poster' or name == "medium_landscape" or name=='medium_poster' or name=='small_fanartimage' or name=='medium_fanartimage' or name=='fanart_noindicators':
|
if name=='thumb' or name=='fanart_image' or name=='small_poster' or name=='tiny_poster' or name == "medium_landscape" or name=='medium_poster' or name=='small_fanartimage' or name=='medium_fanartimage' or name=='fanart_noindicators':
|
||||||
|
@ -147,10 +145,9 @@ class PlaybackUtils():
|
||||||
list.setArt({name:path})
|
list.setArt({name:path})
|
||||||
return list
|
return list
|
||||||
|
|
||||||
|
|
||||||
def setListItemProps(self, server, id, listItem, result):
|
def setListItemProps(self, server, id, listItem, result):
|
||||||
# set up item and item info
|
# set up item and item info
|
||||||
userid = downloadUtils.getUserId()
|
userid = self.downloadUtils.getUserId()
|
||||||
thumbID = id
|
thumbID = id
|
||||||
eppNum = -1
|
eppNum = -1
|
||||||
seasonNum = -1
|
seasonNum = -1
|
||||||
|
@ -216,3 +213,124 @@ class PlaybackUtils():
|
||||||
listItem.setInfo('video', {'mpaa': result.get("OfficialRating")})
|
listItem.setInfo('video', {'mpaa': result.get("OfficialRating")})
|
||||||
listItem.setInfo('video', {'genre': genre})
|
listItem.setInfo('video', {'genre': genre})
|
||||||
|
|
||||||
|
def seekToPosition(self, seekTo):
|
||||||
|
|
||||||
|
#Set a loop to wait for positive confirmation of playback
|
||||||
|
count = 0
|
||||||
|
while not xbmc.Player().isPlaying():
|
||||||
|
count = count + 1
|
||||||
|
if count >= 10:
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
xbmc.sleep(500)
|
||||||
|
|
||||||
|
#Jump to resume point
|
||||||
|
jumpBackSec = 10#int(self.settings.getSetting("resumeJumpBack"))
|
||||||
|
seekToTime = seekTo - jumpBackSec
|
||||||
|
count = 0
|
||||||
|
while xbmc.Player().getTime() < (seekToTime - 5) and count < 11: # only try 10 times
|
||||||
|
count = count + 1
|
||||||
|
#xbmc.Player().pause
|
||||||
|
#xbmc.sleep(100)
|
||||||
|
xbmc.Player().seekTime(seekToTime)
|
||||||
|
xbmc.sleep(100)
|
||||||
|
#xbmc.Player().play()
|
||||||
|
|
||||||
|
def PLAYAllItems(self, items, startPositionTicks):
|
||||||
|
utils.logMsg("PlayBackUtils", "== ENTER: PLAYAllItems ==")
|
||||||
|
utils.logMsg("PlayBackUtils", "Items : " + str(items))
|
||||||
|
userid = self.downloadUtils.getUserId()
|
||||||
|
server = self.downloadUtils.getServer()
|
||||||
|
|
||||||
|
playlist = xbmc.PlayList(xbmc.PLAYLIST_VIDEO)
|
||||||
|
playlist.clear()
|
||||||
|
started = False
|
||||||
|
|
||||||
|
for itemID in items:
|
||||||
|
|
||||||
|
utils.logMsg("PlayBackUtils", "Adding Item to Playlist : " + itemID)
|
||||||
|
item_url = "http://" + server + "/mediabrowser/Users/" + userid + "/Items/" + itemID + "?format=json"
|
||||||
|
jsonData = self.downloadUtils.downloadUrl(item_url, suppress=False, popup=1 )
|
||||||
|
|
||||||
|
item_data = json.loads(jsonData)
|
||||||
|
added = self.addPlaylistItem(playlist, item_data, server, userid)
|
||||||
|
if(added and started == False):
|
||||||
|
started = True
|
||||||
|
utils.logMsg("PlayBackUtils", "Starting Playback Pre")
|
||||||
|
xbmc.Player().play(playlist)
|
||||||
|
|
||||||
|
if(started == False):
|
||||||
|
utils.logMsg("PlayBackUtils", "Starting Playback Post")
|
||||||
|
xbmc.Player().play(playlist)
|
||||||
|
|
||||||
|
#seek to position
|
||||||
|
seekTime = 0
|
||||||
|
if(startPositionTicks != None):
|
||||||
|
seekTime = (startPositionTicks / 1000) / 10000
|
||||||
|
|
||||||
|
if seekTime > 0:
|
||||||
|
self.seekToPosition(seekTime)
|
||||||
|
|
||||||
|
def AddToPlaylist(self, itemIds):
|
||||||
|
utils.logMsg("PlayBackUtils", "== ENTER: PLAYAllItems ==")
|
||||||
|
userid = self.downloadUtils.getUserId()
|
||||||
|
server = self.downloadUtils.getServer()
|
||||||
|
|
||||||
|
playlist = xbmc.PlayList(xbmc.PLAYLIST_VIDEO)
|
||||||
|
|
||||||
|
for itemID in itemIds:
|
||||||
|
|
||||||
|
utils.logMsg("PlayBackUtils", "Adding Item to Playlist : " + itemID)
|
||||||
|
item_url = "http://" + server + "/mediabrowser/Users/" + userid + "/Items/" + itemID + "?format=json"
|
||||||
|
jsonData = self.downloadUtils.downloadUrl(item_url, suppress=False, popup=1 )
|
||||||
|
|
||||||
|
item_data = json.loads(jsonData)
|
||||||
|
self.addPlaylistItem(playlist, item_data, server, userid)
|
||||||
|
|
||||||
|
return playlist
|
||||||
|
|
||||||
|
def addPlaylistItem(self, playlist, item, server, userid):
|
||||||
|
|
||||||
|
id = item.get("Id")
|
||||||
|
|
||||||
|
playurl = PlayUtils().getPlayUrl(server, id, item)
|
||||||
|
utils.logMsg("PlayBackUtils", "Play URL: " + playurl)
|
||||||
|
thumbPath = API().getArtwork(item, "Primary")
|
||||||
|
listItem = xbmcgui.ListItem(path=playurl, iconImage=thumbPath, thumbnailImage=thumbPath)
|
||||||
|
self.setListItemProps(server, id, listItem, item)
|
||||||
|
|
||||||
|
# Can not play virtual items
|
||||||
|
if (item.get("LocationType") == "Virtual") or (item.get("IsPlaceHolder") == True):
|
||||||
|
|
||||||
|
xbmcgui.Dialog().ok(self.language(30128), self.language(30129))
|
||||||
|
return False
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
|
watchedurl = 'http://' + server + '/mediabrowser/Users/'+ userid + '/PlayedItems/' + id
|
||||||
|
positionurl = 'http://' + server + '/mediabrowser/Users/'+ userid + '/PlayingItems/' + id
|
||||||
|
deleteurl = 'http://' + server + '/mediabrowser/Items/' + id
|
||||||
|
|
||||||
|
# set the current playing info
|
||||||
|
WINDOW = xbmcgui.Window( 10000 )
|
||||||
|
WINDOW.setProperty(playurl + "watchedurl", watchedurl)
|
||||||
|
WINDOW.setProperty(playurl + "positionurl", positionurl)
|
||||||
|
WINDOW.setProperty(playurl + "deleteurl", "")
|
||||||
|
|
||||||
|
if item.get("Type") == "Episode" and self.settings.getSetting("offerDelete")=="true":
|
||||||
|
WINDOW.setProperty(playurl + "deleteurl", deleteurl)
|
||||||
|
|
||||||
|
WINDOW.setProperty(playurl + "runtimeticks", str(item.get("RunTimeTicks")))
|
||||||
|
WINDOW.setProperty(playurl+"type", item.get("Type"))
|
||||||
|
WINDOW.setProperty(playurl + "item_id", id)
|
||||||
|
|
||||||
|
if (item.get("Type") == "Episode"):
|
||||||
|
WINDOW.setProperty(playurl + "refresh_id", item.get("SeriesId"))
|
||||||
|
else:
|
||||||
|
WINDOW.setProperty(playurl + "refresh_id", id)
|
||||||
|
|
||||||
|
utils.logMsg("PlayBackUtils", "PlayList Item Url : " + str(playurl))
|
||||||
|
|
||||||
|
playlist.add(playurl, listItem)
|
||||||
|
|
||||||
|
return True
|
|
@ -12,9 +12,9 @@ from DownloadUtils import DownloadUtils
|
||||||
from PlayUtils import PlayUtils
|
from PlayUtils import PlayUtils
|
||||||
from ClientInformation import ClientInformation
|
from ClientInformation import ClientInformation
|
||||||
from LibrarySync import LibrarySync
|
from LibrarySync import LibrarySync
|
||||||
|
from PlaybackUtils import PlaybackUtils
|
||||||
librarySync = LibrarySync()
|
librarySync = LibrarySync()
|
||||||
|
|
||||||
|
|
||||||
# service class for playback monitoring
|
# service class for playback monitoring
|
||||||
class Player( xbmc.Player ):
|
class Player( xbmc.Player ):
|
||||||
|
|
||||||
|
@ -211,7 +211,7 @@ class Player( xbmc.Player ):
|
||||||
itemType = WINDOW.getProperty(currentFile + "type")
|
itemType = WINDOW.getProperty(currentFile + "type")
|
||||||
seekTime = WINDOW.getProperty(currentFile + "seektime")
|
seekTime = WINDOW.getProperty(currentFile + "seektime")
|
||||||
if seekTime != "":
|
if seekTime != "":
|
||||||
self.seekToPosition(int(seekTime))
|
PlaybackUtils().seekToPosition(int(seekTime))
|
||||||
|
|
||||||
if(item_id == None or len(item_id) == 0):
|
if(item_id == None or len(item_id) == 0):
|
||||||
return
|
return
|
||||||
|
@ -298,16 +298,3 @@ class Player( xbmc.Player ):
|
||||||
self.printDebug("emby Service -> onPlayBackStopped")
|
self.printDebug("emby Service -> onPlayBackStopped")
|
||||||
self.stopAll()
|
self.stopAll()
|
||||||
|
|
||||||
def seekToPosition(self, seekTo):
|
|
||||||
|
|
||||||
#Jump to resume point
|
|
||||||
jumpBackSec = 10
|
|
||||||
seekToTime = seekTo - jumpBackSec
|
|
||||||
count = 0
|
|
||||||
while xbmc.Player().getTime() < (seekToTime - 5) and count < 11: # only try 10 times
|
|
||||||
count = count + 1
|
|
||||||
#xbmc.Player().pause()
|
|
||||||
xbmc.sleep(100)
|
|
||||||
xbmc.Player().seekTime(seekToTime)
|
|
||||||
xbmc.sleep(100)
|
|
||||||
#xbmc.Player().play()
|
|
||||||
|
|
Loading…
Reference in a new issue