mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-11-29 16:50:13 +01:00
2021-11-11 Fred Gleason <fredg@paravelsystems.com>
* Added a 'ListCarts()' method to the 'rivwebpyapi' API. Signed-off-by: Fred Gleason <fredg@paravelsystems.com>
This commit is contained in:
@@ -22607,3 +22607,5 @@
|
|||||||
2021-11-10 Fred Gleason <fredg@paravelsystems.com>
|
2021-11-10 Fred Gleason <fredg@paravelsystems.com>
|
||||||
* Added 'all' to the set of available cart types in
|
* Added 'all' to the set of available cart types in
|
||||||
'web/tests/listcarts.html'.
|
'web/tests/listcarts.html'.
|
||||||
|
2021-11-11 Fred Gleason <fredg@paravelsystems.com>
|
||||||
|
* Added a 'ListCarts()' method to the 'rivwebpyapi' API.
|
||||||
|
|||||||
@@ -18,6 +18,8 @@
|
|||||||
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
import datetime
|
import datetime
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
import requests
|
import requests
|
||||||
@@ -195,6 +197,91 @@ class rivwebpyapi(object):
|
|||||||
self.__connection_username=username
|
self.__connection_username=username
|
||||||
self.__connection_password=password
|
self.__connection_password=password
|
||||||
|
|
||||||
|
def ListCarts(self,group_name='',filter_string='',cart_type='all',
|
||||||
|
include_cuts=False):
|
||||||
|
"""
|
||||||
|
Returns a list of Rivendell carts (dictionary)
|
||||||
|
|
||||||
|
Takes the following arguments:
|
||||||
|
|
||||||
|
group_name - Filter returns to only include carts belonging to
|
||||||
|
the specified group. Default is to not filter by
|
||||||
|
group. (string)
|
||||||
|
|
||||||
|
filter_string - Filter returns to only include carts matching the
|
||||||
|
filter string. Default is not to filter by phrase.
|
||||||
|
(string)
|
||||||
|
|
||||||
|
cart_type - Filter returns to only include carts matching the
|
||||||
|
specified type. Recognized values are 'all', 'audio'
|
||||||
|
or 'macro'. Default is 'all'. (string)
|
||||||
|
|
||||||
|
include_cuts - Include cut information in the return. Default is
|
||||||
|
False. (boolean)
|
||||||
|
"""
|
||||||
|
|
||||||
|
#
|
||||||
|
# Build the WebAPI arguments
|
||||||
|
#
|
||||||
|
postdata={
|
||||||
|
'COMMAND': '6',
|
||||||
|
'LOGIN_NAME': self.__connection_username,
|
||||||
|
'PASSWORD': self.__connection_password,
|
||||||
|
'GROUP_NAME': str(group_name),
|
||||||
|
'FILTER': filter_string,
|
||||||
|
'TYPE': cart_type.lower(),
|
||||||
|
'INCLUDE_CUTS': '0'
|
||||||
|
}
|
||||||
|
if(include_cuts):
|
||||||
|
postdata['INCLUDE_CUTS']='1'
|
||||||
|
|
||||||
|
#
|
||||||
|
# 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={
|
||||||
|
'number': 'integer',
|
||||||
|
'type': 'string',
|
||||||
|
'groupName': 'string',
|
||||||
|
'title': 'string',
|
||||||
|
'artist': 'string',
|
||||||
|
'album': 'string',
|
||||||
|
'year': 'integer',
|
||||||
|
'label': 'string',
|
||||||
|
'client': 'string',
|
||||||
|
'agency': 'string',
|
||||||
|
'publisher': 'string',
|
||||||
|
'composer': 'string',
|
||||||
|
'conductor': 'string',
|
||||||
|
'userDefined': 'string',
|
||||||
|
'usageCode': 'integer',
|
||||||
|
'forcedLength': 'string',
|
||||||
|
'averageLength': 'string',
|
||||||
|
'lengthDeviation': 'string',
|
||||||
|
'averageSegueLength': 'string',
|
||||||
|
'averageHookLength': 'string',
|
||||||
|
'minimumTalkLength': 'string',
|
||||||
|
'maximumTalkLength': 'string',
|
||||||
|
'cutQuantity': 'integer',
|
||||||
|
'lastCutPlayed': 'integer',
|
||||||
|
'enforceLength': 'boolean',
|
||||||
|
'asyncronous': 'boolean',
|
||||||
|
'owner': 'string',
|
||||||
|
'metadataDatetime': 'datetime',
|
||||||
|
'songId': 'string'
|
||||||
|
}
|
||||||
|
handler=RivWebPyApi_ListHandler(base_tag='cart',fields=fields)
|
||||||
|
print(r.text)
|
||||||
|
xml.sax.parseString(r.text,handler)
|
||||||
|
|
||||||
|
return handler.output()
|
||||||
|
|
||||||
def ListGroup(self,group_name):
|
def ListGroup(self,group_name):
|
||||||
"""
|
"""
|
||||||
Returns a list of Rivendell groups (dictionary).
|
Returns a list of Rivendell groups (dictionary).
|
||||||
|
|||||||
@@ -20,7 +20,8 @@
|
|||||||
##
|
##
|
||||||
## Use automake to process this into a Makefile.in
|
## Use automake to process this into a Makefile.in
|
||||||
|
|
||||||
EXTRA_DIST = list_group.py\
|
EXTRA_DIST = list_carts.py\
|
||||||
|
list_group.py\
|
||||||
list_groups.py\
|
list_groups.py\
|
||||||
list_log.py\
|
list_log.py\
|
||||||
list_logs.py\
|
list_logs.py\
|
||||||
|
|||||||
107
apis/rivwebpyapi/tests/list_carts.py
Executable file
107
apis/rivwebpyapi/tests/list_carts.py
Executable file
@@ -0,0 +1,107 @@
|
|||||||
|
#!%PYTHON_BANGPATH%
|
||||||
|
|
||||||
|
# list_carts.py
|
||||||
|
#
|
||||||
|
# RivWebPyApi test script for Rivendell
|
||||||
|
#
|
||||||
|
# Test the ListLogs Web API call
|
||||||
|
#
|
||||||
|
# (C) Copyright 2021 Fred Gleason <fredg@paravelsystems.com>
|
||||||
|
#
|
||||||
|
# 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_type='all'
|
||||||
|
include_cuts=False
|
||||||
|
group_name=''
|
||||||
|
filter_string=''
|
||||||
|
|
||||||
|
#
|
||||||
|
# Get login parameters
|
||||||
|
#
|
||||||
|
usage='list_carts --url=<rd-url> --username=<rd-username> [--password=<passwd>] [--audio-only] [--macro-only] [--include-cuts] [--group-name=<name>] [--filter-string=<str>]'
|
||||||
|
for arg in sys.argv:
|
||||||
|
f0=arg.split('=')
|
||||||
|
if(len(f0)==1):
|
||||||
|
if(f0[0]=='--audio-only'):
|
||||||
|
cart_type='audio'
|
||||||
|
if(f0[0]=='--macro-only'):
|
||||||
|
cart_type='macro'
|
||||||
|
if(f0[0]=='--include-cuts'):
|
||||||
|
include_cuts=True
|
||||||
|
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]=='--group-name'):
|
||||||
|
group_name=f0[1]
|
||||||
|
if(f0[0]=='--filter-string'):
|
||||||
|
filter_string=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)
|
||||||
|
carts=webapi.ListCarts(group_name=group_name,filter_string=filter_string,
|
||||||
|
cart_type=cart_type,include_cuts=include_cuts)
|
||||||
|
|
||||||
|
#
|
||||||
|
# Display the cart list
|
||||||
|
#
|
||||||
|
for cart in carts:
|
||||||
|
print('number: '+str(cart['number']))
|
||||||
|
print('type: '+str(cart['type']))
|
||||||
|
print('groupName: '+str(cart['groupName']))
|
||||||
|
print('title: '+str(cart['title']))
|
||||||
|
print('artist: '+str(cart['artist']))
|
||||||
|
print('album: '+str(cart['album']))
|
||||||
|
print('year: '+str(cart['year']))
|
||||||
|
print('label: '+str(cart['label']))
|
||||||
|
print('client: '+str(cart['client']))
|
||||||
|
print('agency: '+str(cart['agency']))
|
||||||
|
print('publisher: '+str(cart['publisher']))
|
||||||
|
print('composer: '+str(cart['composer']))
|
||||||
|
print('conductor: '+str(cart['conductor']))
|
||||||
|
print('userDefined: '+str(cart['userDefined']))
|
||||||
|
print('usageCode: '+str(cart['usageCode']))
|
||||||
|
print('forcedLength: '+str(cart['forcedLength']))
|
||||||
|
print('averageLength: '+str(cart['averageLength']))
|
||||||
|
print('lengthDeviation: '+str(cart['lengthDeviation']))
|
||||||
|
print('averageSegueLength: '+str(cart['averageSegueLength']))
|
||||||
|
print('averageHookLength: '+str(cart['averageHookLength']))
|
||||||
|
print('minimumTalkLength: '+str(cart['minimumTalkLength']))
|
||||||
|
print('maximumTalkLength: '+str(cart['maximumTalkLength']))
|
||||||
|
print('cutQuantity: '+str(cart['cutQuantity']))
|
||||||
|
print('lastCutPlayed: '+str(cart['lastCutPlayed']))
|
||||||
|
print('enforceLength: '+str(cart['enforceLength']))
|
||||||
|
print('asyncronous: '+str(cart['asyncronous']))
|
||||||
|
print('owner: '+str(cart['owner']))
|
||||||
|
print('metadataDatetime: '+str(cart['metadataDatetime']))
|
||||||
|
print('songId: '+str(cart['songId']))
|
||||||
|
print('')
|
||||||
@@ -174,7 +174,10 @@ void Xport::ListCarts()
|
|||||||
printf("Status: 200\n\n");
|
printf("Status: 200\n\n");
|
||||||
printf("<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n");
|
printf("<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n");
|
||||||
printf("<cartList>\n");
|
printf("<cartList>\n");
|
||||||
printf("%s\n",(const char *)RDCart::xml(q,include_cuts,true).toUtf8());
|
QByteArray data=RDCart::xml(q,include_cuts,true).toUtf8();
|
||||||
|
// printf("%s\n",RDCart::xml(q,include_cuts,true).toUtf8().constData());
|
||||||
|
fwrite(data,1,data.size(),stdout);
|
||||||
|
rda->syslog(LOG_NOTICE,"xml size: %d",data.size());
|
||||||
printf("</cartList>\n");
|
printf("</cartList>\n");
|
||||||
delete q;
|
delete q;
|
||||||
Exit(0);
|
Exit(0);
|
||||||
|
|||||||
Reference in New Issue
Block a user