|  |  | @ -49,6 +49,9 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  | #define MODULE_NAME "LogStatsLog" |  |  |  | #define MODULE_NAME "LogStatsLog" | 
			
		
	
		
		
			
				
					
					|  |  |  | #define OUTPUT_BUFFER_SIZE 16384 |  |  |  | #define OUTPUT_BUFFER_SIZE 16384 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | #define LOG_STATS_TOTALS  (1<<0) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | #define LOG_STATS_THREADS (1<<1) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | TmEcode LogStatsLogThreadInit(ThreadVars *, void *, void **); |  |  |  | TmEcode LogStatsLogThreadInit(ThreadVars *, void *, void **); | 
			
		
	
		
		
			
				
					
					|  |  |  | TmEcode LogStatsLogThreadDeinit(ThreadVars *, void *); |  |  |  | TmEcode LogStatsLogThreadDeinit(ThreadVars *, void *); | 
			
		
	
		
		
			
				
					
					|  |  |  | void LogStatsLogExitPrintStats(ThreadVars *, void *); |  |  |  | void LogStatsLogExitPrintStats(ThreadVars *, void *); | 
			
		
	
	
		
		
			
				
					|  |  | @ -100,6 +103,7 @@ int LogStatsLogger(ThreadVars *tv, void *thread_data, const StatsTable *st) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     /* global stats */ |  |  |  |     /* global stats */ | 
			
		
	
		
		
			
				
					
					|  |  |  |     uint32_t u = 0; |  |  |  |     uint32_t u = 0; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (aft->statslog_ctx->flags & LOG_STATS_TOTALS) { | 
			
		
	
		
		
			
				
					
					|  |  |  |         for (u = 0; u < st->nstats; u++) { |  |  |  |         for (u = 0; u < st->nstats; u++) { | 
			
		
	
		
		
			
				
					
					|  |  |  |             if (st->stats[u].name == NULL) |  |  |  |             if (st->stats[u].name == NULL) | 
			
		
	
		
		
			
				
					
					|  |  |  |                 continue; |  |  |  |                 continue; | 
			
		
	
	
		
		
			
				
					|  |  | @ -116,9 +120,10 @@ int LogStatsLogger(ThreadVars *tv, void *thread_data, const StatsTable *st) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             MemBufferWriteString(aft->buffer, "%s", line); |  |  |  |             MemBufferWriteString(aft->buffer, "%s", line); | 
			
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     /* per thread stats */ |  |  |  |     /* per thread stats */ | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (st->tstats != NULL) { |  |  |  |     if (st->tstats != NULL && aft->statslog_ctx->flags & LOG_STATS_THREADS) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         /* for each thread (store) */ |  |  |  |         /* for each thread (store) */ | 
			
		
	
		
		
			
				
					
					|  |  |  |         uint32_t x; |  |  |  |         uint32_t x; | 
			
		
	
		
		
			
				
					
					|  |  |  |         for (x = 0; x < st->ntstats; x++) { |  |  |  |         for (x = 0; x < st->ntstats; x++) { | 
			
		
	
	
		
		
			
				
					|  |  | @ -228,6 +233,22 @@ OutputCtx *LogStatsLogInitCtx(ConfNode *conf) | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |     memset(statslog_ctx, 0x00, sizeof(LogStatsFileCtx)); |  |  |  |     memset(statslog_ctx, 0x00, sizeof(LogStatsFileCtx)); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     statslog_ctx->flags = LOG_STATS_TOTALS; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if (conf != NULL) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         const char *totals = ConfNodeLookupChildValue(conf, "totals"); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         const char *threads = ConfNodeLookupChildValue(conf, "threads"); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         SCLogDebug("totals %s threads %s", totals, threads); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         if (totals != NULL && ConfValIsFalse(totals)) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             statslog_ctx->flags &= ~LOG_STATS_TOTALS; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         if (threads != NULL && ConfValIsTrue(threads)) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             statslog_ctx->flags |= LOG_STATS_THREADS; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         SCLogDebug("statslog_ctx->flags %08x", statslog_ctx->flags); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     statslog_ctx->file_ctx = file_ctx; |  |  |  |     statslog_ctx->file_ctx = file_ctx; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     OutputCtx *output_ctx = SCCalloc(1, sizeof(OutputCtx)); |  |  |  |     OutputCtx *output_ctx = SCCalloc(1, sizeof(OutputCtx)); | 
			
		
	
	
		
		
			
				
					|  |  | 
 |