/* listlogs_test.c * * Test the listlog library. * * (C) Copyright 2015 Todd Baker * * 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 #include #include #include #include #include #include int main(int argc,char *argv[]) { int i; struct rd_log *logs=0; char buf[BUFSIZ]; char *p; char svcname[11]={0}; char logname[65]={0}; long int trackable=0; unsigned numrecs; char *host; char *user; char *passwd; char ticket[41]=""; char filter[255]; long int recent=0; 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 Service Name (default is All) ==> "); if(fgets(buf,sizeof(buf),stdin) != NULL) { strncpy(svcname,buf,10); } fflush(stdin); printf("Please enter the Log Name (default is All) ==> "); if(fgets(buf,sizeof(buf),stdin) != NULL) { strncpy(logname,buf,64); } fflush(stdin); printf("Please enter the Filter string (default is none) ==> "); if(fgets(buf,sizeof(buf),stdin) != NULL) { strncpy(filter,buf,255); } fflush(stdin); printf("Please enter 1 if you want trackable logs ==>"); if (fgets(buf,sizeof(buf),stdin) != NULL) { trackable = strtol(buf,&p,10); if ( (buf[0] != '\n') && ((*p != '\n') && (*p != '\0'))) { fprintf(stderr," Illegal Characters detected! Exiting.\n"); exit(0); } } printf("Please enter 1 if you want only recent logs ==>"); if (fgets(buf,sizeof(buf),stdin) != NULL) { recent = strtol(buf,&p,10); if ( (buf[0] != '\n') && ((*p != '\n') && (*p != '\0'))) { fprintf(stderr," Illegal Characters detected! Exiting.\n"); exit(0); } } // 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_ListLogs(&logs, host, user, passwd, ticket, &svcname[0], &logname[0], (int)trackable, filter, (int)recent, 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 403: fprintf(stderr," ERROR: Invalid User Information During ListLogs call\n"); break; default: fprintf(stderr, "Unknown Error occurred ==> %d\n",result); } exit(256); } // // List the results // for(i=0;i 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;itkt_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_ListLogs(&logs, host, user, passwd, ticket, &svcname[0], &logname[0], (int)trackable, filter, recent, user_agent, &numrecs); if(result<0) { fprintf(stderr,"Error: Web function Failure!\n"); exit(256); } // // List the results // for(i=0;i