/*
stats.c

Statistics for tremmaster

Copyright (C) 2009 Darklegion Development

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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

#ifndef _WIN32

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <signal.h>
#include <stdio.h>
#include <string.h>
#include <time.h>
#include <tdb.h>

#include "common.h"

#define MAX_DATA_SIZE 1024
#define CS_FILENAME   "clientStats.tdb"

/*
====================
RecordClientStat
====================
*/
void RecordClientStat( const char *address, const char *version, const char *renderer )
{
  TDB_CONTEXT *tctx = NULL;
  TDB_DATA    key, data;
  char        ipText[ 22 ];
  char        dataText[ MAX_DATA_SIZE ] = { 0 };
  char        *p;
  int         i;

  tctx = tdb_open( CS_FILENAME, 0, 0, O_RDWR|O_CREAT, S_IRUSR|S_IWUSR );

  if( !tctx )
  {
		MsgPrint( MSG_DEBUG, "Couldn't open %s\n", CS_FILENAME );
    return;
  }

  strncpy( ipText, address, 22 );
  if( ( p = strrchr( ipText, ':' ) ) ) // Remove port
    *p = '\0';

  key.dptr = ipText;
  key.dsize = strlen( ipText );

  strncat( dataText, "\"", MAX_DATA_SIZE );
  strncat( dataText, version, MAX_DATA_SIZE );

  // Remove last three tokens (the date)
  for( i = 0; i < 3; i++ )
  {
    if( ( p = strrchr( dataText, ' ' ) ) )
      *p = '\0';
  }
  strncat( dataText, "\"", MAX_DATA_SIZE );

  strncat( dataText, " \"", MAX_DATA_SIZE );
  strncat( dataText, renderer, MAX_DATA_SIZE );
  strncat( dataText, "\"", MAX_DATA_SIZE );

  data.dptr = dataText;
  data.dsize = strlen( dataText );

  if( tdb_store( tctx, key, data, 0 ) < 0 )
		MsgPrint( MSG_DEBUG, "tdb_store failed\n" );

  tdb_close( tctx );
	MsgPrint( MSG_DEBUG, "Recorded client stat for %s\n", address );
}

#define GS_FILENAME   "gameStats.tdb"

/*
====================
RecordGameStat
====================
*/
void RecordGameStat( const char *address, const char *dataText )
{
  TDB_CONTEXT *tctx = NULL;
  TDB_DATA    key, data;
  char        keyText[ MAX_DATA_SIZE ] = { 0 };
  char        *p;
  time_t      tm = time( NULL );

  tctx = tdb_open( GS_FILENAME, 0, 0, O_RDWR|O_CREAT, S_IRUSR|S_IWUSR );

  if( !tctx )
  {
		MsgPrint( MSG_DEBUG, "Couldn't open %s\n", GS_FILENAME );
    return;
  }

  strncpy( keyText, address, 22 );
  if( ( p = strrchr( keyText, ':' ) ) ) // Remove port
    *p = '\0';

  strncat( keyText, " ", MAX_DATA_SIZE );
  strncat( keyText, asctime( gmtime( &tm ) ), MAX_DATA_SIZE );

  key.dptr = keyText;
  key.dsize = strlen( keyText );

  data.dptr = (char *)dataText;
  data.dsize = strlen( dataText );

  if( tdb_store( tctx, key, data, 0 ) < 0 )
		MsgPrint( MSG_DEBUG, "tdb_store failed\n" );

  tdb_close( tctx );
	MsgPrint( MSG_NORMAL, "Recorded game stat from %s\n", address );
}

#endif