File: log.c

package info (click to toggle)
fsp 2.81.b24-1
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 1,904 kB
  • ctags: 1,423
  • sloc: ansic: 9,215; sh: 3,639; makefile: 212; lex: 130; csh: 77; python: 22
file content (87 lines) | stat: -rw-r--r-- 2,857 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
   /*********************************************************************\
   *  Copyright (c) 2003 by Radim Kolar (hsn@cybermail.net)              *
   *  Copyright (c) 1991 by Wen-King Su (wen-king@vlsi.cs.caltech.edu)   *
   *                                                                     *
   *  You may copy or modify this file in any manner you wish, provided  *
   *  that this notice is always included, and that you hold the author  *
   *  harmless for any loss or damage resulting from the installation or *
   *  use of this software.                                              *
   \*********************************************************************/

#include "tweak.h"
#include "server_def.h"
#include "s_extern.h"
#include "my-string.h"
#include <stdarg.h>

int logfd = -1;  /* logfile file descriptor */
int tlogfd = -1; /* transfer log file descriptor */

/****************************************************************************
 * A slightly better logging function.. It now takes a format string and    *
 * any number of args.                                                      *
 ****************************************************************************/

#define LOGBUFFER 1024+80
static char logbuf[LOGBUFFER];	/* buffer for log message */
static size_t logpos = 0;	/* current log message length */

/* append some text to the log message */
void fsploga(const char *fmt, ...)
{
    va_list args;

    va_start(args, fmt);
    /* fmt = va_arg(args, char *); */
    vsprintf(logbuf + logpos, fmt, args);
    logpos += strlen(logbuf + logpos);
    va_end(args);
}

/* add a datestamp to begining of the log message, clear text in buffer */
void fsplogs (void)
{

    int timelen;
    char *timestr;

    timestr = (char *)ctime(&cur_time);
    timelen = strlen(timestr) - 1; /* strip the CR */
    timestr[timelen] = '\0';
    strcpy(logbuf, timestr);
    logbuf[timelen] = ' ';
    logpos = timelen + 1;
}

/* flush logfile */
void fsplogf (void)
{
  if(dbug) {
	     fwrite("[LOG] ",6,1,stdout);
	     fwrite(logbuf,logpos,1,stdout);
	     fflush(stdout);
	   }
   write(logfd, logbuf, logpos);
   logpos = 0;
}

/* wu ftpd xferlog subsystem */
static char tlogbuf[LOGBUFFER];	/* buffer for log message */

void xferlog(char direction, const char *filename,unsigned long filesize,const char *hostname)
{
    size_t pos=0,timelen;
    char *timestr;

    if(!tlogname) return; /* xfer logging is not enabled */

    /* current-time */
    timestr = (char *)ctime(&cur_time);
    timelen = strlen(timestr) - 1; /* strip the CR */
    timestr[timelen] = '\0';
    strcpy(tlogbuf, timestr);
    pos = timelen;
    /* transfer-time, remote-host, file-size, file-name, ... */
    pos+=sprintf(tlogbuf+pos," 1 %s %lu %s b * %c a fsp fsp 0 * c\n",hostname,filesize,filename,direction);
   write(tlogfd, tlogbuf, pos);
}