From 2f15913d2a311e35192ed0de79d8517a7d955fe6 Mon Sep 17 00:00:00 2001 From: Fred Gleason Date: Fri, 3 Dec 2021 17:57:43 -0500 Subject: [PATCH] 2021-12-03 Fred Gleason * Added a 'ListCuts()' method to the 'rivwebpyapi' API. Signed-off-by: Fred Gleason --- ChangeLog | 2 + apis/rivwebpyapi/api/rivwebpyapi.py | 86 +++++++++++++++++++++ apis/rivwebpyapi/tests/Makefile.am | 1 + apis/rivwebpyapi/tests/list_cuts.py | 112 ++++++++++++++++++++++++++++ 4 files changed, 201 insertions(+) create mode 100755 apis/rivwebpyapi/tests/list_cuts.py diff --git a/ChangeLog b/ChangeLog index 14747cd8..67bc41f8 100644 --- a/ChangeLog +++ b/ChangeLog @@ -22649,3 +22649,5 @@ * Added a 'ListScheduleCodes()' method to the 'rivwebpyapi' API. 2021-12-03 Fred Gleason * Added a 'ListCut()' method to the 'rivwebpyapi' API. +2021-12-03 Fred Gleason + * Added a 'ListCuts()' method to the 'rivwebpyapi' API. diff --git a/apis/rivwebpyapi/api/rivwebpyapi.py b/apis/rivwebpyapi/api/rivwebpyapi.py index 33cfe0f5..3845a0db 100755 --- a/apis/rivwebpyapi/api/rivwebpyapi.py +++ b/apis/rivwebpyapi/api/rivwebpyapi.py @@ -500,6 +500,92 @@ class rivwebpyapi(object): return handler.output() + def ListCuts(self,cart_number): + """ + Returns Rivendell cuts belonging to a cart (dictionary). + + Takes the following argument: + + cart_number - The number of the desired cart, in the range + 1 - 999999 (integer) + + """ + + if((cart_number<1)or(cart_number>999999)): + raise ValueError('invalid cart number') + + # + # Build the WebAPI arguments + # + postdata={ + 'COMMAND': '9', + 'LOGIN_NAME': self.__connection_username, + 'PASSWORD': self.__connection_password, + 'CART_NUMBER': str(cart_number) + } + + # + # Fetch the XML + # + r=requests.post(self.__connection_url,data=postdata) + if(r.status_code!=requests.codes.ok): + r.raise_for_status() + + # + # Generate the output dictionary + # + fields={ + 'cutName': 'string', + 'cartNumber': 'integer', + 'cutNumber': 'integer', + 'evergreen': 'boolean', + 'description': 'string', + 'outcue': 'string', + 'isrc': 'string', + 'isci': 'string', + 'recordingMbId': 'string', + 'releaseMbId': 'string', + 'length': 'integer', + 'originDatetime': 'datetime', + 'startDatetime': 'datetime', + 'endDatetime': 'datetime', + 'sun': 'boolean', + 'mon': 'boolean', + 'tue': 'boolean', + 'wed': 'boolean', + 'thu': 'boolean', + 'fri': 'boolean', + 'sat': 'boolean', + 'startDaypart': 'time', + 'endDaypart': 'time', + 'originName': 'string', + 'originLoginName': 'string', + 'sourceHostname': 'string', + 'weight': 'integer', + 'lastPlayDatetime': 'datetime', + 'playCounter': 'integer', + 'codingFormat': 'integer', + 'sampleRate': 'integer', + 'bitRate': 'integer', + 'channels': 'integer', + 'playGain': 'integer', + 'startPoint': 'integer', + 'endPoint': 'integer', + 'fadeupPoint': 'integer', + 'fadedownPoint': 'integer', + 'segueStartPoint': 'integer', + 'segueEndPoint': 'integer', + 'segueGain': 'integer', + 'hookStartPoint': 'integer', + 'hookEndPoint': 'integer', + 'talkStartPoint': 'integer', + 'talkEndPoint': 'integer' + } + handler=RivWebPyApi_ListHandler(base_tag='cut',fields=fields) + xml.sax.parseString(r.text,handler) + + return handler.output() + def ListGroup(self,group_name): """ Returns a list of Rivendell groups (dictionary). diff --git a/apis/rivwebpyapi/tests/Makefile.am b/apis/rivwebpyapi/tests/Makefile.am index 3ada368f..dd7b6f31 100644 --- a/apis/rivwebpyapi/tests/Makefile.am +++ b/apis/rivwebpyapi/tests/Makefile.am @@ -24,6 +24,7 @@ EXTRA_DIST = list_cart.py\ list_cart_sched_codes.py\ list_carts.py\ list_cut.py\ + list_cuts.py\ list_group.py\ list_groups.py\ list_log.py\ diff --git a/apis/rivwebpyapi/tests/list_cuts.py b/apis/rivwebpyapi/tests/list_cuts.py new file mode 100755 index 00000000..dd4b8984 --- /dev/null +++ b/apis/rivwebpyapi/tests/list_cuts.py @@ -0,0 +1,112 @@ +#!%PYTHON_BANGPATH% + +# list_cuts.py +# +# RivWebPyApi test script for Rivendell +# +# Test the ListCuts 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 + +url=''; +username='' +password='' +cart_number=0 +include_cuts=False + +# +# Get login parameters +# +usage='list_cuts --url= --username= --cart-number= [--password=]' +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]=='--cart-number'): + cart_number=int(f0[1]) + +if(not password): + password=getpass.getpass() +if((not url)or(not username)): + print(usage) + sys.exit(1) + +# +# Get the cart list +# +webapi=rivwebpyapi.rivwebpyapi(url=url,username=username,password=password) +cuts=webapi.ListCuts(cart_number=cart_number) + +# +# Display the cart list +# +for cut in cuts: + print('cutName: '+str(cut['cutName'])) + print('cartNumber: '+str(cut['cartNumber'])) + print('cutNumber: '+str(cut['cutNumber'])) + print('evergreen: '+str(cut['evergreen'])) + print('description: '+str(cut['description'])) + print('outcue: '+str(cut['outcue'])) + print('isrc: '+str(cut['isrc'])) + print('isci: '+str(cut['isci'])) + print('recordingMbId: '+str(cut['recordingMbId'])) + print('releaseMbId: '+str(cut['releaseMbId'])) + print('length: '+str(cut['length'])) + print('originDatetime: '+str(cut['originDatetime'])) + print('startDatetime: '+str(cut['startDatetime'])) + print('endDatetime: '+str(cut['endDatetime'])) + print('sun: '+str(cut['sun'])) + print('mon: '+str(cut['mon'])) + print('tue: '+str(cut['tue'])) + print('wed: '+str(cut['wed'])) + print('thu: '+str(cut['thu'])) + print('fri: '+str(cut['fri'])) + print('sat: '+str(cut['sat'])) + print('startDaypart: '+str(cut['startDaypart'])) + print('endDaypart: '+str(cut['endDaypart'])) + print('originName: '+str(cut['originName'])) + print('originLoginName: '+str(cut['originLoginName'])) + print('sourceHostname: '+str(cut['sourceHostname'])) + print('weight: '+str(cut['weight'])) + print('lastPlayDatetime: '+str(cut['lastPlayDatetime'])) + print('playCounter: '+str(cut['playCounter'])) + print('codingFormat: '+str(cut['codingFormat'])) + print('sampleRate: '+str(cut['sampleRate'])) + print('bitRate: '+str(cut['bitRate'])) + print('channels: '+str(cut['channels'])) + print('playGain: '+str(cut['playGain'])) + print('startPoint: '+str(cut['startPoint'])) + print('endPoint: '+str(cut['endPoint'])) + print('fadeupPoint: '+str(cut['fadeupPoint'])) + print('fadedownPoint: '+str(cut['fadedownPoint'])) + print('segueStartPoint: '+str(cut['segueStartPoint'])) + print('segueEndPoint: '+str(cut['segueEndPoint'])) + print('segueGain: '+str(cut['segueGain'])) + print('hookStartPoint: '+str(cut['hookStartPoint'])) + print('hookEndPoint: '+str(cut['hookEndPoint'])) + print('talkStartPoint: '+str(cut['talkStartPoint'])) + print('talkEndPoint: '+str(cut['talkEndPoint'])) + print('')