mirror of
https://github.com/pkkid/python-plexapi
synced 2024-11-22 11:43:13 +00:00
autopep
This commit is contained in:
parent
740e7a5b9b
commit
3839b9f2d8
1 changed files with 89 additions and 34 deletions
|
@ -4,6 +4,7 @@ PlexAPI Client
|
|||
To understand how this works, read this page:
|
||||
https://github.com/plexinc/plex-media-player/wiki/Remote-control-API
|
||||
"""
|
||||
|
||||
import requests
|
||||
from requests.status_codes import _codes as codes
|
||||
from plexapi import BASE_HEADERS, TIMEOUT, log, utils
|
||||
|
@ -27,7 +28,8 @@ class PlexClient(object):
|
|||
self.machineIdentifier = data.attrib.get('machineIdentifier')
|
||||
self.product = data.attrib.get('product')
|
||||
self.protocol = data.attrib.get('protocol')
|
||||
self.protocolCapabilities = data.attrib.get('protocolCapabilities', '').split(',')
|
||||
self.protocolCapabilities = data.attrib.get(
|
||||
'protocolCapabilities', '').split(',')
|
||||
self.protocolVersion = data.attrib.get('protocolVersion')
|
||||
self.platform = data.attrib.get('platform')
|
||||
self.platformVersion = data.attrib.get('platformVersion')
|
||||
|
@ -46,7 +48,7 @@ class PlexClient(object):
|
|||
except Exception as err:
|
||||
log.error('%s: %s', self.baseurl, err)
|
||||
raise NotFound('No client found at: %s' % self.baseurl)
|
||||
|
||||
|
||||
def headers(self):
|
||||
headers = BASE_HEADERS
|
||||
if self.token:
|
||||
|
@ -74,16 +76,18 @@ class PlexClient(object):
|
|||
command = command.strip('/')
|
||||
controller = command.split('/')[0]
|
||||
if controller not in self.protocolCapabilities:
|
||||
raise Unsupported('Client %s does not support the %s controller.' % (self.title, controller))
|
||||
raise Unsupported(
|
||||
'Client %s does not support the %s controller.' % (self.title, controller))
|
||||
path = '/player/%s%s' % (command, utils.joinArgs(params))
|
||||
headers = {'X-Plex-Target-Client-Identifier':self.machineIdentifier}
|
||||
self._commandId += 1; params['commandID'] = self._commandId
|
||||
headers = {'X-Plex-Target-Client-Identifier': self.machineIdentifier}
|
||||
self._commandId += 1
|
||||
params['commandID'] = self._commandId
|
||||
proxy = self._proxyThroughServer if proxy is None else proxy
|
||||
if proxy:
|
||||
return self.server.query(path, headers=headers)
|
||||
path = '/player/%s%s' % (command, utils.joinArgs(params))
|
||||
return self.query(path, headers=headers)
|
||||
|
||||
|
||||
def url(self, path):
|
||||
if self.token:
|
||||
delim = '&' if '?' in path else '?'
|
||||
|
@ -93,23 +97,37 @@ class PlexClient(object):
|
|||
# Navigation Commands
|
||||
# These commands navigate around the user-interface.
|
||||
def contextMenu(self): self.sendCommand('navigation/contextMenu')
|
||||
|
||||
def goBack(self): self.sendCommand('navigation/back')
|
||||
|
||||
def goToHome(self): self.sendCommand('navigation/home')
|
||||
|
||||
def goToMusic(self): self.sendCommand('navigation/music')
|
||||
|
||||
def moveDown(self): self.sendCommand('navigation/moveDown')
|
||||
|
||||
def moveLeft(self): self.sendCommand('navigation/moveLeft')
|
||||
|
||||
def moveRight(self): self.sendCommand('navigation/moveRight')
|
||||
|
||||
def moveUp(self): self.sendCommand('navigation/moveUp')
|
||||
|
||||
def nextLetter(self): self.sendCommand('navigation/nextLetter')
|
||||
|
||||
def pageDown(self): self.sendCommand('navigation/pageDown')
|
||||
|
||||
def pageUp(self): self.sendCommand('navigation/pageUp')
|
||||
|
||||
def previousLetter(self): self.sendCommand('navigation/previousLetter')
|
||||
|
||||
def select(self): self.sendCommand('navigation/select')
|
||||
|
||||
def toggleOSD(self): self.sendCommand('navigation/toggleOSD')
|
||||
|
||||
def goToMedia(self, media, **params):
|
||||
if not self.server:
|
||||
raise Unsupported('A server must be specified before using this command.')
|
||||
raise Unsupported(
|
||||
'A server must be specified before using this command.')
|
||||
server_url = media.server.baseurl.split(':')
|
||||
self.sendCommand('mirror/details', **dict({
|
||||
'machineIdentifier': self.server.machineIdentifier,
|
||||
|
@ -124,25 +142,54 @@ class PlexClient(object):
|
|||
# is in case there are multiple things happening (e.g. music in the background, photo
|
||||
# slideshow in the foreground).
|
||||
def pause(self, mtype): self.sendCommand('playback/pause', type=mtype)
|
||||
|
||||
def play(self, mtype): self.sendCommand('playback/play', type=mtype)
|
||||
def refreshPlayQueue(self, playQueueID, mtype=None): self.sendCommand('playback/refreshPlayQueue', playQueueID=playQueueID, type=mtype)
|
||||
def seekTo(self, offset, mtype=None): self.sendCommand('playback/seekTo', offset=offset, type=mtype) # offset in milliseconds
|
||||
def skipNext(self, mtype=None): self.sendCommand('playback/skipNext', type=mtype)
|
||||
def skipPrevious(self, mtype=None): self.sendCommand('playback/skipPrevious', type=mtype)
|
||||
def skipTo(self, key, mtype=None): self.sendCommand('playback/skipTo', key=key, type=mtype) # skips to item with matching key
|
||||
def stepBack(self, mtype=None): self.sendCommand('playback/stepBack', type=mtype)
|
||||
def stepForward(self, mtype): self.sendCommand('playback/stepForward', type=mtype)
|
||||
|
||||
def refreshPlayQueue(self, playQueueID, mtype=None): self.sendCommand(
|
||||
'playback/refreshPlayQueue', playQueueID=playQueueID, type=mtype)
|
||||
|
||||
def seekTo(self, offset, mtype=None): self.sendCommand(
|
||||
'playback/seekTo', offset=offset, type=mtype) # offset in milliseconds
|
||||
|
||||
def skipNext(self, mtype=None): self.sendCommand(
|
||||
'playback/skipNext', type=mtype)
|
||||
|
||||
def skipPrevious(self, mtype=None): self.sendCommand(
|
||||
'playback/skipPrevious', type=mtype)
|
||||
|
||||
def skipTo(self, key, mtype=None): self.sendCommand(
|
||||
'playback/skipTo', key=key, type=mtype) # skips to item with matching key
|
||||
|
||||
def stepBack(self, mtype=None): self.sendCommand(
|
||||
'playback/stepBack', type=mtype)
|
||||
|
||||
def stepForward(self, mtype): self.sendCommand(
|
||||
'playback/stepForward', type=mtype)
|
||||
|
||||
def stop(self, mtype): self.sendCommand('playback/stop', type=mtype)
|
||||
def setRepeat(self, repeat, mtype): self.setParameters(repeat=repeat, mtype=mtype) # 0=off, 1=repeatone, 2=repeatall
|
||||
def setShuffle(self, shuffle, mtype): self.setParameters(shuffle=shuffle, mtype=mtype) # 0=off, 1=on
|
||||
def setVolume(self, volume, mtype): self.setParameters(volume=volume, mtype=mtype) # 0-100
|
||||
def setAudioStream(self, audioStreamID, mtype): self.setStreams(audioStreamID=audioStreamID, mtype=mtype)
|
||||
def setSubtitleStream(self, subtitleStreamID, mtype): self.setStreams(subtitleStreamID=subtitleStreamID, mtype=mtype)
|
||||
def setVideoStream(self, videoStreamID, mtype): self.setStreams(videoStreamID=videoStreamID, mtype=mtype)
|
||||
|
||||
|
||||
def setRepeat(self, repeat, mtype): self.setParameters(
|
||||
repeat=repeat, mtype=mtype) # 0=off, 1=repeatone, 2=repeatall
|
||||
|
||||
def setShuffle(self, shuffle, mtype): self.setParameters(
|
||||
shuffle=shuffle, mtype=mtype) # 0=off, 1=on
|
||||
|
||||
def setVolume(self, volume, mtype): self.setParameters(
|
||||
volume=volume, mtype=mtype) # 0-100
|
||||
|
||||
def setAudioStream(self, audioStreamID, mtype): self.setStreams(
|
||||
audioStreamID=audioStreamID, mtype=mtype)
|
||||
|
||||
def setSubtitleStream(self, subtitleStreamID, mtype): self.setStreams(
|
||||
subtitleStreamID=subtitleStreamID, mtype=mtype)
|
||||
|
||||
def setVideoStream(self, videoStreamID, mtype): self.setStreams(
|
||||
videoStreamID=videoStreamID, mtype=mtype)
|
||||
|
||||
def playMedia(self, media, **params):
|
||||
if not self.server:
|
||||
raise Unsupported('A server must be specified before using this command.')
|
||||
raise Unsupported(
|
||||
'A server must be specified before using this command.')
|
||||
server_url = media.server.baseurl.split(':')
|
||||
playqueue = self.server.createPlayQueue(media)
|
||||
self.sendCommand('playback/playMedia', **dict({
|
||||
|
@ -152,26 +199,34 @@ class PlexClient(object):
|
|||
'key': media.key,
|
||||
'containerKey': '/playQueues/%s?window=100&own=1' % playqueue.playQueueID,
|
||||
}, **params))
|
||||
|
||||
|
||||
def setParameters(self, volume=None, shuffle=None, repeat=None, mtype=None):
|
||||
params = {}
|
||||
if repeat is not None: params['repeat'] = repeat # 0=off, 1=repeatone, 2=repeatall
|
||||
if shuffle is not None: params['shuffle'] = shuffle # 0=off, 1=on
|
||||
if volume is not None: params['volume'] = volume # 0-100
|
||||
if mtype is not None: params['type'] = mtype # music,photo,video
|
||||
if repeat is not None:
|
||||
params['repeat'] = repeat # 0=off, 1=repeatone, 2=repeatall
|
||||
if shuffle is not None:
|
||||
params['shuffle'] = shuffle # 0=off, 1=on
|
||||
if volume is not None:
|
||||
params['volume'] = volume # 0-100
|
||||
if mtype is not None:
|
||||
params['type'] = mtype # music,photo,video
|
||||
self.sendCommand('playback/setParameters', **params)
|
||||
|
||||
|
||||
def setStreams(self, audioStreamID=None, subtitleStreamID=None, videoStreamID=None, mtype=None):
|
||||
params = {}
|
||||
if audioStreamID is not None: params['audioStreamID'] = audioStreamID
|
||||
if subtitleStreamID is not None: params['subtitleStreamID'] = subtitleStreamID
|
||||
if videoStreamID is not None: params['videoStreamID'] = videoStreamID
|
||||
if mtype is not None: params['type'] = mtype # music,photo,video
|
||||
if audioStreamID is not None:
|
||||
params['audioStreamID'] = audioStreamID
|
||||
if subtitleStreamID is not None:
|
||||
params['subtitleStreamID'] = subtitleStreamID
|
||||
if videoStreamID is not None:
|
||||
params['videoStreamID'] = videoStreamID
|
||||
if mtype is not None:
|
||||
params['type'] = mtype # music,photo,video
|
||||
self.sendCommand('playback/setStreams', **params)
|
||||
|
||||
|
||||
# Timeline Commands
|
||||
def timeline(self):
|
||||
return self.sendCommand('timeline/poll', **{'wait':1, 'commandID':4})
|
||||
return self.sendCommand('timeline/poll', **{'wait': 1, 'commandID': 4})
|
||||
|
||||
def isPlayingMedia(self, includePaused=False):
|
||||
for mediatype in self.timeline():
|
||||
|
|
Loading…
Reference in a new issue