mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-04-24 17:37:53 +02:00
* Fixed buffer overflow vulnerabilities in the rivwebcapi test harnesses. * Modified rd_createticket(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_addcart(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_addcut(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_addlog(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_assignschedcode(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_audioinfo(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_audiostore(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_copyaudio(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_deletelog(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_editcart(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_editcut(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_export(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_exportpeaks(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listcart(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listcarts(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listcartschedcodes(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listcut(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listcuts(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listgroup(7) in the rivwebcapi to process UTF-8 strings correctly. * Modified rd_listgroups(7) in the rivwebcapi to process UTF-8 strings correctly.
378 lines
18 KiB
C
378 lines
18 KiB
C
/* listlog_test.c
|
|
*
|
|
* Test the listlog library.
|
|
*
|
|
* (C) Copyright 2015 Todd Baker <bakert@rfa.org>
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include <rivwebcapi/rd_listlog.h>
|
|
#include <rivwebcapi/rd_createticket.h>
|
|
#include <rivwebcapi/rd_getuseragent.h>
|
|
#include <rivwebcapi/rd_getversion.h>
|
|
|
|
int main(int argc,char *argv[])
|
|
{
|
|
int i;
|
|
struct rd_logline *logline=0;
|
|
char buf[BUFSIZ];
|
|
unsigned numrecs;
|
|
char *host;
|
|
char *user;
|
|
char *passwd;
|
|
char ticket[41]="";
|
|
char starttime_buf[15];
|
|
char user_agent[255]={0};
|
|
|
|
/* Get the Rivendell Host, User and Password if set in env */
|
|
if (getenv("RIVHOST")!=NULL) {
|
|
host = getenv("RIVHOST");
|
|
}
|
|
else {
|
|
host="localhost";
|
|
}
|
|
|
|
if (getenv("RIVUSER")!=NULL) {
|
|
user = getenv("RIVUSER");
|
|
}
|
|
else {
|
|
user="USER";
|
|
}
|
|
|
|
if (getenv("RIVPASS")!=NULL) {
|
|
passwd = getenv("RIVPASS");
|
|
}
|
|
else {
|
|
passwd = "";
|
|
}
|
|
|
|
printf("Please enter the Log Name ==> ");
|
|
if (fgets(buf,sizeof(buf),stdin) != NULL)
|
|
{
|
|
}
|
|
|
|
// Add the User Agent and Version
|
|
strcat(user_agent,RD_GetUserAgent());
|
|
strcat(user_agent,RD_GetVersion());
|
|
strcat(user_agent," (Test Suite)");
|
|
|
|
//
|
|
// Call the function
|
|
//
|
|
int result= RD_ListLog(&logline,
|
|
host,
|
|
user,
|
|
passwd,
|
|
ticket,
|
|
buf,
|
|
user_agent,
|
|
&numrecs);
|
|
if(result<0) {
|
|
fprintf(stderr,"Error: Web function Failure!\n");
|
|
exit(256);
|
|
}
|
|
|
|
if ((result< 200 || result > 299) &&
|
|
(result != 0))
|
|
{
|
|
switch(result) {
|
|
case 400:
|
|
fprintf(stderr,"ERROR: Missing Cart Number! \n");
|
|
break;
|
|
case 404:
|
|
fprintf(stderr,"ERROR: No Such Cart Exists! \n");
|
|
break;
|
|
default:
|
|
fprintf(stderr, "Unknown Error occurred ==> %d",result);
|
|
}
|
|
exit(256);
|
|
}
|
|
//
|
|
// List the results
|
|
//
|
|
for(i=0;i<numrecs;i++) {
|
|
printf(" LogLine Line Number: %d\n",logline[i].logline_line);
|
|
printf(" LogLine Id: %d\n",logline[i].logline_id);
|
|
printf(" LogLine Type: %d\n",logline[i].logline_type);
|
|
printf(" LogLine Cart Type: %d\n",logline[i].logline_cart_type);
|
|
printf(" LogLine Cart Number: %u\n",logline[i].logline_cart_number);
|
|
printf(" LogLine Cut Number: %d\n",logline[i].logline_cut_number);
|
|
printf(" LogLine Group Name: %s\n",logline[i].logline_group_name);
|
|
printf(" LogLine Group Color: %s\n",logline[i].logline_group_color);
|
|
printf(" LogLine Title: %s\n",logline[i].logline_title);
|
|
printf(" LogLine Artist: %s\n",logline[i].logline_artist);
|
|
printf(" LogLine Album: %s\n",logline[i].logline_album);
|
|
printf(" LogLine Year: %d\n",logline[i].logline_year);
|
|
printf(" LogLine Label: %s\n",logline[i].logline_label);
|
|
printf(" LogLine Client: %s\n",logline[i].logline_client);
|
|
printf(" LogLine Agency: %s\n",logline[i].logline_agency);
|
|
printf(" LogLine Publisher: %s\n",logline[i].logline_publisher);
|
|
printf(" LogLine Composer: %s\n",logline[i].logline_composer);
|
|
printf(" LogLine Conductor: %s\n",logline[i].logline_conductor);
|
|
printf(" LogLine User Defined: %s\n",logline[i].logline_user_defined);
|
|
printf(" LogLine Usage Code: %d\n",logline[i].logline_usage_code);
|
|
printf(" LogLine Enforce Length: %d\n",logline[i].logline_enforce_length);
|
|
printf(" LogLine Forced Length: %d\n",logline[i].logline_forced_length);
|
|
printf(" LogLine Evergreen: %d\n",logline[i].logline_evergreen);
|
|
printf(" LogLine Source: %d\n",logline[i].logline_source);
|
|
printf(" LogLine Time Type: %d\n",logline[i].logline_time_type);
|
|
if(RD_Cnv_msec_to_TString(starttime_buf,14,logline[i].logline_starttime)==0) {
|
|
printf(" LogLine Start Time: %d\n",
|
|
logline[i].logline_starttime);
|
|
}
|
|
else {
|
|
printf(" LogLine Start Time: %d [%s]\n",
|
|
logline[i].logline_starttime,starttime_buf);
|
|
}
|
|
printf(" LogLine Transition Type: %d\n",logline[i].logline_transition_type);
|
|
printf(" LogLine Cut Quantity: %d\n",logline[i].logline_cut_quantity);
|
|
printf(" LogLine Last Cut Played: %d\n",logline[i].logline_last_cut_played);
|
|
printf(" LogLine Marker Comment: %s\n",logline[i].logline_marker_comment);
|
|
printf(" LogLine Marker Label: %s\n",logline[i].logline_marker_label);
|
|
printf(" LogLine Origin User: %s\n",logline[i].logline_origin_user);
|
|
printf(" LogLine Origin DateTime\n");
|
|
printf("LogLine OriginDateTime year value : %d\n",logline[i].logline_origin_datetime.tm_year);
|
|
printf("LogLine OriginDateTime mon value : %d\n",logline[i].logline_origin_datetime.tm_mon);
|
|
printf("LogLine OriginDateTime mday value : %d\n",logline[i].logline_origin_datetime.tm_mday);
|
|
printf("LogLine OriginDateTime day value : %d\n",logline[i].logline_origin_datetime.tm_wday);
|
|
printf("LogLine OriginDateTime hour value : %d\n",logline[i].logline_origin_datetime.tm_hour);
|
|
printf("LogLine OriginDateTime min value : %d\n",logline[i].logline_origin_datetime.tm_min);
|
|
printf("LogLine OriginDateTime sec value : %d\n",logline[i].logline_origin_datetime.tm_sec);
|
|
printf("LogLine OriginDateTime isdst : %d\n",logline[i].logline_origin_datetime.tm_isdst);
|
|
printf(" LogLine Start Point Cart: %d\n",logline[i].logline_start_point_cart);
|
|
printf(" LogLineStart Point Log: %d\n",logline[i].logline_start_point_log);
|
|
printf(" LogLine End Point Cart: %d\n",logline[i].logline_end_point_cart);
|
|
printf(" LogLine End Point Log: %d\n",logline[i].logline_end_point_log);
|
|
printf(" LogLine Segue Start Point Cart: %d\n",logline[i].logline_segue_start_point_cart);
|
|
printf(" LogLine Segue Start Point Log: %d\n",logline[i].logline_segue_start_point_log);
|
|
printf(" LogLine Segue End Point Cart: %d\n",logline[i].logline_segue_end_point_cart);
|
|
printf(" LogLine Segue End Point Log: %d\n",logline[i].logline_segue_end_point_log);
|
|
printf(" LogLine Segue Gain: %d\n",logline[i].logline_segue_gain);
|
|
printf(" LogLine FadeUp Point Cart: %d\n",logline[i].logline_fadeup_point_cart);
|
|
printf(" LogLine FadeUp Point Log: %d\n",logline[i].logline_fadeup_point_log);
|
|
printf(" LogLine FadeUp Gain: %d\n",logline[i].logline_fadeup_gain);
|
|
printf(" LogLine FadeDown Point Cart: %d\n",logline[i].logline_fadedown_point_cart);
|
|
printf(" LogLine FadeDown Point Log: %d\n",logline[i].logline_fadedown_point_log);
|
|
printf(" LogLine DuckUp Gain: %d\n",logline[i].logline_duckup_gain);
|
|
printf(" LogLine DuckDown Gain: %d\n",logline[i].logline_duckdown_gain);
|
|
printf(" LogLine Talk Start Point: %d\n",logline[i].logline_talk_start_point);
|
|
printf(" LogLine Talk End Point: %d\n",logline[i].logline_talk_end_point);
|
|
printf(" LogLine Hook Mode: %d\n",logline[i].logline_hook_mode);
|
|
printf(" LogLine Hook Start Point: %d\n",logline[i].logline_hook_start_point);
|
|
printf(" LogLine Hook End Point: %d\n",logline[i].logline_hook_end_point);
|
|
|
|
printf(" LogLine Event Length: %d\n",logline[i].logline_event_length);
|
|
printf(" LogLine Link Event Name: %s\n",logline[i].logline_link_event_name);
|
|
printf(" LogLine Link Start Time: %d\n",logline[i].logline_link_starttime);
|
|
printf(" LogLine Link Start Slop: %d\n",logline[i].logline_link_start_slop);
|
|
printf(" LogLine Link End Slop: %d\n",logline[i].logline_link_end_slop);
|
|
printf(" LogLine Link Id: %d\n",logline[i].logline_link_id);
|
|
printf(" LogLine Link Embedded: %d\n",logline[i].logline_link_embedded);
|
|
printf(" LogLine Ext Start Time: %d\n",logline[i].logline_ext_starttime);
|
|
printf(" LogLine Ext Length: %d\n",logline[i].logline_ext_length);
|
|
printf(" LogLine Ext Cart Name: %s\n",logline[i].logline_ext_cart_name);
|
|
printf(" LogLine Ext Data: %s\n",logline[i].logline_ext_data);
|
|
printf(" LogLine Ext Event Id: %s\n",logline[i].logline_ext_event_id);
|
|
printf(" LogLine Ext Annc Type: %s\n",logline[i].logline_ext_annc_type);
|
|
|
|
printf("\n");
|
|
}
|
|
|
|
//
|
|
// Free the Log Line list when finished with it
|
|
//
|
|
free(logline);
|
|
|
|
// Add test of create_ticket function
|
|
|
|
struct rd_ticketinfo *myticket=0;
|
|
numrecs=0;
|
|
|
|
result = RD_CreateTicket( &myticket,
|
|
host,
|
|
user,
|
|
passwd,
|
|
user_agent,
|
|
&numrecs);
|
|
|
|
if ((result< 200 || result > 299) &&
|
|
(result != 0))
|
|
{
|
|
switch(result) {
|
|
case 403:
|
|
fprintf(stderr," ERROR: Invalid User Information During Create Ticket\n");
|
|
break;
|
|
default:
|
|
fprintf(stderr, "Unknown Error occurred ==> %d\n",result);
|
|
}
|
|
exit(256);
|
|
}
|
|
|
|
// We got a ticket created - use it and do the call again
|
|
//
|
|
// List the Results
|
|
//
|
|
for(i=0;i<numrecs;i++) {
|
|
printf(" Ticket: %s\n",myticket[i].ticket);
|
|
printf("Ticket Expire year value = %d\n",myticket->tkt_expiration_datetime.tm_year);
|
|
printf("Ticket Expire month value = %d\n",myticket->tkt_expiration_datetime.tm_mon);
|
|
printf("Ticket Expire day value = %d\n",myticket->tkt_expiration_datetime.tm_mday);
|
|
printf("Ticket Expire wday value = %d\n",myticket->tkt_expiration_datetime.tm_wday);
|
|
printf("Ticket Expire hour value = %d\n",myticket->tkt_expiration_datetime.tm_hour);
|
|
printf("Ticket Expire min value = %d\n",myticket->tkt_expiration_datetime.tm_min);
|
|
printf("Ticket Expire sec value = %d\n",myticket->tkt_expiration_datetime.tm_sec);
|
|
printf("Ticket Expire isdst value = %d\n",myticket->tkt_expiration_datetime.tm_isdst);
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
user="";
|
|
passwd="";
|
|
strcpy( ticket,myticket->ticket);
|
|
fprintf(stderr, "Ticket was copied - = %s\n",ticket);
|
|
//
|
|
// Call the function
|
|
//
|
|
result= RD_ListLog(&logline,
|
|
host,
|
|
user,
|
|
passwd,
|
|
ticket,
|
|
buf,
|
|
user_agent,
|
|
&numrecs);
|
|
if(result<0) {
|
|
fprintf(stderr,"Error: Web function Failure!\n");
|
|
exit(256);
|
|
}
|
|
|
|
if ((result< 200 || result > 299) &&
|
|
(result != 0))
|
|
{
|
|
switch(result) {
|
|
case 400:
|
|
fprintf(stderr,"ERROR: Missing Cart Number! \n");
|
|
break;
|
|
case 404:
|
|
fprintf(stderr,"ERROR: No Such Cart Exists! \n");
|
|
break;
|
|
default:
|
|
fprintf(stderr, "Unknown Error occurred ==> %d",result);
|
|
}
|
|
exit(256);
|
|
}
|
|
//
|
|
// List the results
|
|
//
|
|
for(i=0;i<numrecs;i++) {
|
|
printf(" LogLine Line Number: %d\n",logline[i].logline_line);
|
|
printf(" LogLine Id: %d\n",logline[i].logline_id);
|
|
printf(" LogLine Type: %d\n",logline[i].logline_type);
|
|
printf(" LogLine Cart Type: %d\n",logline[i].logline_cart_type);
|
|
printf(" LogLine Cart Number: %u\n",logline[i].logline_cart_number);
|
|
printf(" LogLine Cut Number: %d\n",logline[i].logline_cut_number);
|
|
printf(" LogLine Group Name: %s\n",logline[i].logline_group_name);
|
|
printf(" LogLine Group Color: %s\n",logline[i].logline_group_color);
|
|
printf(" LogLine Title: %s\n",logline[i].logline_title);
|
|
printf(" LogLine Artist: %s\n",logline[i].logline_artist);
|
|
printf(" LogLine Album: %s\n",logline[i].logline_album);
|
|
printf(" LogLine Year: %d\n",logline[i].logline_year);
|
|
printf(" LogLine Label: %s\n",logline[i].logline_label);
|
|
printf(" LogLine Client: %s\n",logline[i].logline_client);
|
|
printf(" LogLine Agency: %s\n",logline[i].logline_agency);
|
|
printf(" LogLine Publisher: %s\n",logline[i].logline_publisher);
|
|
printf(" LogLine Composer: %s\n",logline[i].logline_composer);
|
|
printf(" LogLine Conductor: %s\n",logline[i].logline_conductor);
|
|
printf(" LogLine User Defined: %s\n",logline[i].logline_user_defined);
|
|
printf(" LogLine Usage Code: %d\n",logline[i].logline_usage_code);
|
|
printf(" LogLine Enforce Length: %d\n",logline[i].logline_enforce_length);
|
|
printf(" LogLine Forced Length: %d\n",logline[i].logline_forced_length);
|
|
printf(" LogLine Evergreen: %d\n",logline[i].logline_evergreen);
|
|
printf(" LogLine Source: %d\n",logline[i].logline_source);
|
|
printf(" LogLine Time Type: %d\n",logline[i].logline_time_type);
|
|
if(RD_Cnv_msec_to_TString(starttime_buf,14,logline[i].logline_starttime)==0) {
|
|
printf(" LogLine Start Time: %d\n",
|
|
logline[i].logline_starttime);
|
|
}
|
|
else {
|
|
printf(" LogLine Start Time: %d [%s]\n",
|
|
logline[i].logline_starttime,starttime_buf);
|
|
}
|
|
printf(" LogLine Transition Type: %d\n",logline[i].logline_transition_type);
|
|
printf(" LogLine Cut Quantity: %d\n",logline[i].logline_cut_quantity);
|
|
printf(" LogLine Last Cut Played: %d\n",logline[i].logline_last_cut_played);
|
|
printf(" LogLine Marker Comment: %s\n",logline[i].logline_marker_comment);
|
|
printf(" LogLine Marker Label: %s\n",logline[i].logline_marker_label);
|
|
printf(" LogLine Origin User: %s\n",logline[i].logline_origin_user);
|
|
printf(" LogLine Origin DateTime\n");
|
|
printf("LogLine OriginDateTime year value : %d\n",logline[i].logline_origin_datetime.tm_year);
|
|
printf("LogLine OriginDateTime mon value : %d\n",logline[i].logline_origin_datetime.tm_mon);
|
|
printf("LogLine OriginDateTime mday value : %d\n",logline[i].logline_origin_datetime.tm_mday);
|
|
printf("LogLine OriginDateTime day value : %d\n",logline[i].logline_origin_datetime.tm_wday);
|
|
printf("LogLine OriginDateTime hour value : %d\n",logline[i].logline_origin_datetime.tm_hour);
|
|
printf("LogLine OriginDateTime min value : %d\n",logline[i].logline_origin_datetime.tm_min);
|
|
printf("LogLine OriginDateTime sec value : %d\n",logline[i].logline_origin_datetime.tm_sec);
|
|
printf("LogLine OriginDateTime isdst : %d\n",logline[i].logline_origin_datetime.tm_isdst);
|
|
printf(" LogLine Start Point Cart: %d\n",logline[i].logline_start_point_cart);
|
|
printf(" LogLineStart Point Log: %d\n",logline[i].logline_start_point_log);
|
|
printf(" LogLine End Point Cart: %d\n",logline[i].logline_end_point_cart);
|
|
printf(" LogLine End Point Log: %d\n",logline[i].logline_end_point_log);
|
|
printf(" LogLine Segue Start Point Cart: %d\n",logline[i].logline_segue_start_point_cart);
|
|
printf(" LogLine Segue Start Point Log: %d\n",logline[i].logline_segue_start_point_log);
|
|
printf(" LogLine Segue End Point Cart: %d\n",logline[i].logline_segue_end_point_cart);
|
|
printf(" LogLine Segue End Point Log: %d\n",logline[i].logline_segue_end_point_log);
|
|
printf(" LogLine Segue Gain: %d\n",logline[i].logline_segue_gain);
|
|
printf(" LogLine FadeUp Point Cart: %d\n",logline[i].logline_fadeup_point_cart);
|
|
printf(" LogLine FadeUp Point Log: %d\n",logline[i].logline_fadeup_point_log);
|
|
printf(" LogLine FadeUp Gain: %d\n",logline[i].logline_fadeup_gain);
|
|
printf(" LogLine FadeDown Point Cart: %d\n",logline[i].logline_fadedown_point_cart);
|
|
printf(" LogLine FadeDown Point Log: %d\n",logline[i].logline_fadedown_point_log);
|
|
printf(" LogLine DuckUp Gain: %d\n",logline[i].logline_duckup_gain);
|
|
printf(" LogLine DuckDown Gain: %d\n",logline[i].logline_duckdown_gain);
|
|
printf(" LogLine Talk Start Point: %d\n",logline[i].logline_talk_start_point);
|
|
printf(" LogLine Talk End Point: %d\n",logline[i].logline_talk_end_point);
|
|
printf(" LogLine Hook Mode: %d\n",logline[i].logline_hook_mode);
|
|
printf(" LogLine Hook Start Point: %d\n",logline[i].logline_hook_start_point);
|
|
printf(" LogLine Hook End Point: %d\n",logline[i].logline_hook_end_point);
|
|
|
|
printf(" LogLine Event Length: %d\n",logline[i].logline_event_length);
|
|
printf(" LogLine Link Event Name: %s\n",logline[i].logline_link_event_name);
|
|
printf(" LogLine Link Start Time: %d\n",logline[i].logline_link_starttime);
|
|
printf(" LogLine Link Start Slop: %d\n",logline[i].logline_link_start_slop);
|
|
printf(" LogLine Link End Slop: %d\n",logline[i].logline_link_end_slop);
|
|
printf(" LogLine Link Id: %d\n",logline[i].logline_link_id);
|
|
printf(" LogLine Link Embedded: %d\n",logline[i].logline_link_embedded);
|
|
printf(" LogLine Ext Start Time: %d\n",logline[i].logline_ext_starttime);
|
|
printf(" LogLine Ext Length: %d\n",logline[i].logline_ext_length);
|
|
printf(" LogLine Ext Cart Name: %s\n",logline[i].logline_ext_cart_name);
|
|
printf(" LogLine Ext Data: %s\n",logline[i].logline_ext_data);
|
|
printf(" LogLine Ext Event Id: %s\n",logline[i].logline_ext_event_id);
|
|
printf(" LogLine Ext Annc Type: %s\n",logline[i].logline_ext_annc_type);
|
|
|
|
printf("\n");
|
|
}
|
|
|
|
//
|
|
// Free the Log Line list when finished with it
|
|
//
|
|
free(logline);
|
|
|
|
exit(0);
|
|
}
|