From 01aa066d2cdd790523fcb42d29ac38ba1a03f808 Mon Sep 17 00:00:00 2001 From: blacktwin Date: Fri, 29 Sep 2017 14:47:45 -0400 Subject: [PATCH] fix for plexapi update removeSection is explicit. --- utility/plex_api_share.py | 37 ++++++++++++++++++++++++++----------- 1 file changed, 26 insertions(+), 11 deletions(-) diff --git a/utility/plex_api_share.py b/utility/plex_api_share.py index aaedc72..379107d 100644 --- a/utility/plex_api_share.py +++ b/utility/plex_api_share.py @@ -4,7 +4,7 @@ Share or unshare libraries. optional arguments: -h, --help show this help message and exit -s [], --share [] To share or to unshare.: - (choices: share, unshare) + (choices: share, share_all, unshare, unshare_all) -u [], --user [] Space separated list of case sensitive names to process. Allowed names are: (choices: All users names) -l [ ...], --libraries [ ...] @@ -13,15 +13,23 @@ optional arguments: (default: All Libraries) Usage: - plex_api_share.py -s unshare -u USER - - Unshared all libraries with USER. - - USER is still exists as a Friend or Home User plex_api_share.py -s share -u USER -l Movies - Shared libraries: ['Movies'] with USER plex_api_share.py -s share -u USER -l Movies "TV Shows" - Shared libraries: ['Movies', 'TV Shows'] with USER + * Double Quote libraries with spaces + + plex_api_share.py -s share_all -u USER + - Shared all libraries with USER. + + plex_api_share.py -s unshare -u USER -l Movies + - Unshared libraries: ['Movies'] from USER + + plex_api_share.py -s unshare_all -u USER + - Unshared all libraries with USER. + - USER is still exists as a Friend or Home User ''' @@ -29,12 +37,13 @@ from plexapi.server import PlexServer import argparse PLEX_URL = 'http://localhost:32400' -PLEX_TOKEN = 'xxxxxxxx' +PLEX_TOKEN = 'xxxxx' plex = PlexServer(PLEX_URL, PLEX_TOKEN) user_lst = [x.title for x in plex.myPlexAccount().users()] sections_lst = [x.title for x in plex.library.sections()] + def share(user, libraries): plex.myPlexAccount().updateFriend(user=user, server=plex, sections=libraries) if not libraries: @@ -42,17 +51,19 @@ def share(user, libraries): else: print('Shared libraries: {libraries} with {user}.'.format(libraries=libraries, user=user)) -def unshare(user): - plex.myPlexAccount().updateFriend(user=user, server=plex, removeSections=True) + +def unshare(user, libraries): + plex.myPlexAccount().updateFriend(user=user, server=plex, removeSections=True, sections=libraries) print('Unshared all libraries with {user}.'.format(user=user)) + if __name__ == "__main__": parser = argparse.ArgumentParser(description="Share or unshare libraries.", formatter_class=argparse.RawTextHelpFormatter) - parser.add_argument('-s', '--share', nargs='?', type=str, required=True, choices=['share', 'unshare'], metavar='', - help='To share or to unshare.: \n' - '(choices: %(choices)s)') + parser.add_argument('-s', '--share', nargs='?', type=str, required=True, + choices=['share', 'share_all', 'unshare', 'unshare_all'], metavar='', + help='To share or to unshare.: \n (choices: %(choices)s)') parser.add_argument('-u', '--user', nargs='?', type=str, required=True, choices=user_lst, metavar='', help='Space separated list of case sensitive names to process. Allowed names are: \n' '(choices: %(choices)s)') @@ -65,6 +76,10 @@ if __name__ == "__main__": if opts.share == 'share': share(opts.user, opts.libraries) elif opts.share == 'unshare': - unshare(opts.user) + unshare(opts.user, opts.libraries) + elif opts.share == 'share_all': + unshare(opts.user, sections_lst) + elif opts.share == 'unshare_all': + unshare(opts.user, sections_lst) else: print('I don\'t know what else you want.')