2005-10-18 03:21:59 +00:00
2005-10-14 16:07:00 +00:00
/*
* Samba Unix / Linux SMB client utility
2005-10-17 15:53:12 +00:00
* Write Eventlog records to a tdb , perform other eventlog related functions
*
2005-10-14 16:07:00 +00:00
*
* Copyright ( C ) Brian Moran 2005.
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* 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 0213 9 , USA .
*/
# include "includes.h"
# undef DBGC_CLASS
# define DBGC_CLASS DBGC_UTIL_EVENTLOG
extern int optind ;
extern char * optarg ;
int opt_debug = 0 ;
static void usage ( char * s )
{
2005-10-18 03:21:59 +00:00
printf ( " \n Usage: %s [OPTION] \n \n " , s ) ;
printf ( " -o write <Eventlog Name> \t \t \t \t \t Writes records to eventlog from STDIN \n " ) ;
printf ( " -o addsource <EventlogName> <sourcename> <msgfileDLLname> \t Adds the specified source & DLL eventlog registry entry \n " ) ;
printf ( " \n Miscellaneous options: \n " ) ;
printf ( " -d \t \t \t \t \t \t \t \t turn debug on \n " ) ;
printf ( " -h \t \t \t \t \t \t \t \t display help \n \n " ) ;
2005-10-14 16:07:00 +00:00
}
static void display_eventlog_names ( void )
{
const char * * elogs ;
int i ;
elogs = lp_eventlog_list ( ) ;
printf ( " Active eventlog names (from smb.conf): \n " ) ;
printf ( " -------------------------------------- \n " ) ;
2005-12-15 18:39:28 +00:00
if ( elogs ) {
for ( i = 0 ; elogs [ i ] ; i + + ) {
printf ( " \t %s \n " , elogs [ i ] ) ;
}
}
else
printf ( " \t <None specified> \n " ) ;
2005-10-14 16:07:00 +00:00
}
2006-12-19 20:16:52 +00:00
static int DoAddSourceCommand ( int argc , char * * argv , BOOL debugflag , char * exename )
2005-10-14 16:07:00 +00:00
{
2005-10-18 03:21:59 +00:00
if ( argc < 3 ) {
printf ( " need more arguments: \n " ) ;
2005-10-20 14:29:24 +00:00
printf ( " -o addsource EventlogName SourceName /path/to/EventMessageFile.dll \n " ) ;
2005-10-18 03:21:59 +00:00
return - 1 ;
2005-10-14 16:07:00 +00:00
}
2005-10-18 03:21:59 +00:00
/* must open the registry before we access it */
if ( ! regdb_init ( ) ) {
printf ( " Can't open the registry. \n " ) ;
return - 1 ;
2005-10-14 16:07:00 +00:00
}
2005-10-18 03:21:59 +00:00
if ( ! eventlog_add_source ( argv [ 0 ] , argv [ 1 ] , argv [ 2 ] ) )
return - 2 ;
return 0 ;
}
2006-12-19 20:16:52 +00:00
static int DoWriteCommand ( int argc , char * * argv , BOOL debugflag , char * exename )
2005-10-18 03:21:59 +00:00
{
FILE * f1 ;
char * argfname ;
2005-11-17 21:07:24 +00:00
ELOG_TDB * etdb ;
2005-10-14 16:07:00 +00:00
2005-10-18 03:21:59 +00:00
/* fixed constants are bad bad bad */
pstring linein ;
BOOL is_eor ;
Eventlog_entry ee ;
2006-06-28 21:56:03 +00:00
int rcnum ;
2005-10-14 16:07:00 +00:00
f1 = stdin ;
if ( ! f1 ) {
printf ( " Can't open STDIN \n " ) ;
return - 1 ;
}
2005-10-18 03:21:59 +00:00
if ( debugflag ) {
printf ( " Starting write for eventlog [%s] \n " , argv [ 0 ] ) ;
2005-10-14 16:07:00 +00:00
display_eventlog_names ( ) ;
}
argfname = argv [ 0 ] ;
2005-11-17 21:07:24 +00:00
if ( ! ( etdb = elog_open_tdb ( argfname , False ) ) ) {
2005-10-18 03:21:59 +00:00
printf ( " can't open the eventlog TDB (%s) \n " , argfname ) ;
2005-10-14 16:07:00 +00:00
return - 1 ;
}
ZERO_STRUCT ( ee ) ; /* MUST initialize between records */
while ( ! feof ( f1 ) ) {
fgets ( linein , sizeof ( linein ) - 1 , f1 ) ;
linein [ strlen ( linein ) - 1 ] = 0 ; /* whack the line delimiter */
2005-10-18 03:21:59 +00:00
if ( debugflag )
2005-10-14 16:07:00 +00:00
printf ( " Read line [%s] \n " , linein ) ;
is_eor = False ;
2005-10-18 03:21:59 +00:00
2006-06-28 21:56:03 +00:00
parse_logentry ( ( char * ) & linein , & ee , & is_eor ) ;
2005-10-18 03:21:59 +00:00
/* should we do something with the return code? */
2005-10-14 16:07:00 +00:00
if ( is_eor ) {
fixup_eventlog_entry ( & ee ) ;
if ( opt_debug )
2005-10-18 03:21:59 +00:00
printf ( " record number [%d], tg [%d] , tw [%d] \n " , ee . record . record_number , ee . record . time_generated , ee . record . time_written ) ;
2005-10-14 16:07:00 +00:00
if ( ee . record . time_generated ! = 0 ) {
/* printf("Writing to the event log\n"); */
2005-11-17 21:07:24 +00:00
rcnum = write_eventlog_tdb ( ELOG_TDB_CTX ( etdb ) , & ee ) ;
2005-10-14 16:07:00 +00:00
if ( ! rcnum ) {
printf ( " Can't write to the event log \n " ) ;
} else {
if ( opt_debug )
printf ( " Wrote record %d \n " ,
rcnum ) ;
}
} else {
if ( opt_debug )
printf ( " <null record> \n " ) ;
}
ZERO_STRUCT ( ee ) ; /* MUST initialize between records */
}
}
2005-11-17 21:07:24 +00:00
elog_close_tdb ( etdb , False ) ;
2005-10-14 16:07:00 +00:00
return 0 ;
}
2005-10-18 03:21:59 +00:00
/* would be nice to use the popT stuff here, however doing so forces us to drag in a lot of other infrastructure */
int main ( int argc , char * argv [ ] )
{
int opt , rc ;
char * exename ;
fstring opname ;
2005-12-28 22:48:54 +00:00
load_case_tables ( ) ;
2005-10-18 03:21:59 +00:00
opt_debug = 0 ; /* todo set this from getopts */
2006-01-28 22:53:04 +00:00
lp_load ( dyn_CONFIGFILE , True , False , False , True ) ;
2005-10-18 03:21:59 +00:00
exename = argv [ 0 ] ;
/* default */
fstrcpy ( opname , " write " ) ; /* the default */
#if 0 /* TESTING CODE */
eventlog_add_source ( " System " , " TestSourceX " , " SomeTestPathX " ) ;
# endif
while ( ( opt = getopt ( argc , argv , " dho: " ) ) ! = EOF ) {
switch ( opt ) {
case ' o ' :
fstrcpy ( opname , optarg ) ;
break ;
case ' h ' :
2006-06-28 21:56:03 +00:00
usage ( exename ) ;
2005-10-18 03:21:59 +00:00
display_eventlog_names ( ) ;
exit ( 0 ) ;
break ;
case ' d ' :
opt_debug = 1 ;
break ;
}
}
argc - = optind ;
argv + = optind ;
if ( argc < 1 ) {
printf ( " \n Not enough arguments! \n " ) ;
usage ( exename ) ;
exit ( 1 ) ;
}
/* note that the separate command types should call usage if they need to... */
while ( 1 ) {
if ( ! StrCaseCmp ( opname , " addsource " ) ) {
rc = DoAddSourceCommand ( argc , argv , opt_debug ,
exename ) ;
break ;
}
if ( ! StrCaseCmp ( opname , " write " ) ) {
rc = DoWriteCommand ( argc , argv , opt_debug , exename ) ;
break ;
}
printf ( " unknown command [%s] \n " , opname ) ;
usage ( exename ) ;
exit ( 1 ) ;
break ;
}
return rc ;
}