From 1287cce718a256417f8d9f5b346106cf1723584b Mon Sep 17 00:00:00 2001 From: Fred Gleason Date: Thu, 9 Dec 2021 16:02:13 -0500 Subject: [PATCH] 2021-12-09 Fred Gleason * Added a 'PostImage()' method to the 'rivwebpyapi' API. Signed-off-by: Fred Gleason --- ChangeLog | 2 + apis/rivwebpyapi/api/rivwebpyapi.py | 29 +++++++++++ apis/rivwebpyapi/tests/Makefile.am | 1 + apis/rivwebpyapi/tests/post_image.py | 73 ++++++++++++++++++++++++++++ 4 files changed, 105 insertions(+) create mode 100755 apis/rivwebpyapi/tests/post_image.py diff --git a/ChangeLog b/ChangeLog index 3fa890af..5c77df5b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -22725,3 +22725,5 @@ * Added a 'PostPodcast()' method to the 'rivwebpyapi' API. 2021-12-09 Fred Gleason * Added a 'RemovePodcast()' method to the 'rivwebpyapi' API. +2021-12-09 Fred Gleason + * Added a 'PostImage()' method to the 'rivwebpyapi' API. diff --git a/apis/rivwebpyapi/api/rivwebpyapi.py b/apis/rivwebpyapi/api/rivwebpyapi.py index 6a96a605..c255becb 100755 --- a/apis/rivwebpyapi/api/rivwebpyapi.py +++ b/apis/rivwebpyapi/api/rivwebpyapi.py @@ -1730,6 +1730,35 @@ class rivwebpyapi(object): return handler.output()[0] + def PostImage(self,image_id): + """ + Upload a podcast image to the remote archive. + + Takes the following argument: + + image_id - ID of the image (integer). + """ + + if(image_id<0): + raise ValueError('invalid image ID') + + # + # Build the WebAPI arguments + # + postdata={ + 'COMMAND': '44', + 'LOGIN_NAME': self.__connection_username, + 'PASSWORD': self.__connection_password, + 'ID': str(image_id) + } + + # + # Fetch the audio data + # + r=requests.post(self.__connection_url,data=postdata) + if(r.status_code!=requests.codes.ok): + self.__throwError(response=r) + def PostPodcast(self,cast_id): """ Upload podcast audio from the Rivendell audio store to the diff --git a/apis/rivwebpyapi/tests/Makefile.am b/apis/rivwebpyapi/tests/Makefile.am index 453f1639..37d519c5 100644 --- a/apis/rivwebpyapi/tests/Makefile.am +++ b/apis/rivwebpyapi/tests/Makefile.am @@ -45,6 +45,7 @@ EXTRA_DIST = add_cart.py\ list_services.py\ list_system_settings.py\ lock_log.py\ + post_image.py\ post_podcast.py\ rehash.py\ remove_cart.py\ diff --git a/apis/rivwebpyapi/tests/post_image.py b/apis/rivwebpyapi/tests/post_image.py new file mode 100755 index 00000000..c2b12da7 --- /dev/null +++ b/apis/rivwebpyapi/tests/post_image.py @@ -0,0 +1,73 @@ +#!%PYTHON_BANGPATH% + +# post_image.py +# +# RivWebPyApi test script for Rivendell +# +# Test the PostImage Web API call +# +# (C) Copyright 2021 Fred Gleason +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public +# License along with this program; if not, write to the Free Software +# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +# + +import getpass +import rivwebpyapi +import sys +def eprint(*args,**kwargs): + print(*args,file=sys.stderr,**kwargs) + +url=''; +username='' +password='' +image_id=-1 + +# +# Get login parameters +# +usage='post_image --url= --username= --image-id=' +for arg in sys.argv: + f0=arg.split('=') + if(len(f0)==2): + if(f0[0]=='--url'): + url=f0[1] + if(f0[0]=='--username'): + username=f0[1] + if(f0[0]=='--password'): + password=f0[1] + if(f0[0]=='--image-id'): + image_id=int(f0[1]) + +if(not password): + password=getpass.getpass() +if((not url)or(not username)): + print(usage) + sys.exit(1) +if(image_id<0): + eprint('you must supply "--image-id"') + sys.exit(1) + +# +# Execute +# +webapi=rivwebpyapi.rivwebpyapi(url=url,username=username,password=password) +try: + webapi.PostImage(image_id=image_id) +except rivwebpyapi.RivWebPyError as err: + eprint('*** ERROR ***') + eprint('Response Code: '+str(err.responseCode)) + eprint('ErrorString: '+str(err.errorString)) + eprint('*************') + eprint('') + sys.exit(1)