2016-03-21 04:26:02 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
2014-12-29 03:21:58 +00:00
|
|
|
"""
|
|
|
|
PlexAPI Examples
|
2015-06-04 04:00:37 +00:00
|
|
|
As of Plex version 0.9.11 I noticed that you must be logged in
|
2014-12-29 03:21:58 +00:00
|
|
|
to browse even the plex server locatewd at localhost. You can
|
|
|
|
run this example suite with the following command:
|
|
|
|
|
|
|
|
>> python examples.py -u <USERNAME> -p <PASSWORD> -s <SERVERNAME>
|
|
|
|
"""
|
|
|
|
import argparse, sys
|
|
|
|
from os.path import dirname, abspath
|
|
|
|
sys.path.append(dirname(dirname(abspath(__file__))))
|
2016-03-15 15:04:53 +00:00
|
|
|
from utils import fetch_server, iter_tests, register
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def list_all_unwatched_content(plex):
|
2014-12-29 03:21:58 +00:00
|
|
|
""" Example 1: List all unwatched content in library """
|
|
|
|
for section in plex.library.sections():
|
2015-02-17 20:35:17 +00:00
|
|
|
print('Unwatched content in %s:' % section.title)
|
2014-12-29 03:21:58 +00:00
|
|
|
for video in section.unwatched():
|
2015-02-17 20:35:17 +00:00
|
|
|
print(' %s' % video.title)
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def mark_all_conan_episodes_watched(plex):
|
2015-06-15 02:45:22 +00:00
|
|
|
""" Example 2: Mark all Friends episodes watched. """
|
|
|
|
plex.library.section('TV Shows').get('Friends').markWatched()
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def list_all_clients(plex):
|
2014-12-29 03:21:58 +00:00
|
|
|
""" Example 3: List all Clients connected to the Server. """
|
|
|
|
for client in plex.clients():
|
2015-02-17 20:35:17 +00:00
|
|
|
print(client.name)
|
2015-06-15 02:45:22 +00:00
|
|
|
else:
|
2015-09-27 08:13:06 +00:00
|
|
|
print('No clients')
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def play_avatar_on_iphone(plex):
|
2015-06-09 02:21:31 +00:00
|
|
|
""" Example 4: Play the Movie Avatar on my iPhone.
|
|
|
|
Note: Client must be on same network as server.
|
|
|
|
"""
|
2014-12-29 03:21:58 +00:00
|
|
|
avatar = plex.library.section('Movies').get('Avatar')
|
2015-06-09 02:19:20 +00:00
|
|
|
client = plex.client("iphone-mike")
|
2014-12-29 03:21:58 +00:00
|
|
|
client.playMedia(avatar)
|
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def search(plex):
|
2014-12-29 03:21:58 +00:00
|
|
|
""" Example 5: List all content with the word 'Game' in the title. """
|
|
|
|
for video in plex.search('Game'):
|
2015-02-17 20:35:17 +00:00
|
|
|
print('%s (%s)' % (video.title, video.TYPE))
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def follow_the_talent(plex):
|
2014-12-29 03:21:58 +00:00
|
|
|
""" Example 6: List all movies directed by the same person as Jurassic Park. """
|
2015-06-15 02:45:22 +00:00
|
|
|
movies = plex.library.section('Movies')
|
|
|
|
jurassic_park = movies.get('Jurassic Park')
|
2014-12-29 03:21:58 +00:00
|
|
|
director = jurassic_park.directors[0]
|
2015-06-15 02:45:22 +00:00
|
|
|
for movie in movies.search(None, director=director):
|
2015-02-17 20:35:17 +00:00
|
|
|
print(movie.title)
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def list_files(plex):
|
2014-12-29 03:21:58 +00:00
|
|
|
""" Example 7: List files for the latest episode of Friends. """
|
2016-03-21 04:26:02 +00:00
|
|
|
thelastone = plex.library.section('TV Shows').get('Friends').episodes()[-1]
|
|
|
|
for part in thelastone.iterParts():
|
2015-02-17 20:35:17 +00:00
|
|
|
print(part.file)
|
2014-12-29 03:21:58 +00:00
|
|
|
|
|
|
|
|
2016-03-15 15:04:53 +00:00
|
|
|
@register()
|
|
|
|
def get_stream_url(plex):
|
2015-06-04 04:00:37 +00:00
|
|
|
""" Example 8: Get a URL you can open in VLC, MPV, etc. """
|
|
|
|
jurassic_park = plex.library.section('Movies').get('Jurassic Park')
|
2015-09-27 08:13:06 +00:00
|
|
|
print('Try running the following command:')
|
|
|
|
print('vlc "%s"' % jurassic_park.getStreamUrl(videoResolution='800x600'))
|
2015-06-04 04:00:37 +00:00
|
|
|
|
|
|
|
|
2014-12-29 03:21:58 +00:00
|
|
|
if __name__ == '__main__':
|
2016-03-14 04:57:04 +00:00
|
|
|
# There are three ways to authenticate:
|
|
|
|
# 1. If the server is running on localhost, just run without any auth.
|
|
|
|
# 2. Pass in --username, --password, and --resource.
|
2016-04-02 06:19:32 +00:00
|
|
|
# 3. Pass in --baseurl, --token
|
2014-12-29 03:21:58 +00:00
|
|
|
parser = argparse.ArgumentParser(description='Run PlexAPI examples.')
|
2016-04-07 05:39:04 +00:00
|
|
|
parser.add_argument('-u', '--username', help='Username for your MyPlex account.')
|
|
|
|
parser.add_argument('-p', '--password', help='Password for your MyPlex account.')
|
2016-04-02 06:19:32 +00:00
|
|
|
parser.add_argument('-r', '--resource', help='Name of the Plex resource (requires user/pass).')
|
|
|
|
parser.add_argument('-b', '--baseurl', help='Baseurl needed for auth token authentication')
|
|
|
|
parser.add_argument('-t', '--token', help='Auth token (instead of user/pass)')
|
|
|
|
parser.add_argument('-q', '--example', help='Only run the specified example.')
|
2016-03-15 18:36:59 +00:00
|
|
|
parser.add_argument('-v', '--verbose', default=False, action='store_true', help='Print verbose logging.')
|
2014-12-29 03:21:58 +00:00
|
|
|
args = parser.parse_args()
|
2016-04-07 05:39:04 +00:00
|
|
|
plex, account = fetch_server(args)
|
2016-03-15 15:04:53 +00:00
|
|
|
for example in iter_tests(args.example):
|
|
|
|
example['func'](plex)
|