logging.c 4.48 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12
/* Icecast
 *
 * This program is distributed under the GNU General Public License, version 2.
 * A copy of this license is included with this source.
 *
 * Copyright 2000-2004, Jack Moffitt <jack@xiph.org, 
 *                      Michael Smith <msmith@xiph.org>,
 *                      oddsock <oddsock@xiph.org>,
 *                      Karl Heyes <karl@xiph.org>
 *                      and others (see AUTHORS for details).
 */

13 14 15 16
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

Jack Moffitt's avatar
Jack Moffitt committed
17 18
#include <stdio.h>
#include <time.h>
19
#include <string.h>
Jack Moffitt's avatar
Jack Moffitt committed
20

Karl Heyes's avatar
Karl Heyes committed
21 22
#include "thread/thread.h"
#include "httpp/httpp.h"
Jack Moffitt's avatar
Jack Moffitt committed
23 24 25 26 27

#include "connection.h"
#include "refbuf.h"
#include "client.h"

28
#include "os.h"
29
#include "cfgfile.h"
Jack Moffitt's avatar
Jack Moffitt committed
30
#include "logging.h"
31
#include "util.h"
Jack Moffitt's avatar
Jack Moffitt committed
32

33 34 35 36
#ifdef _WIN32
#define snprintf _snprintf
#endif

Jack Moffitt's avatar
Jack Moffitt committed
37
/* the global log descriptors */
Michael Smith's avatar
Michael Smith committed
38 39
int errorlog = 0;
int accesslog = 0;
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 88 89 90 91 92 93 94

#ifdef _WIN32
/* Since strftime's %z option on win32 is different, we need
   to go through a few loops to get the same info as %z */
int get_clf_time (char *buffer, unsigned len, struct tm *t)
{
    char    sign;
    char    *timezone_string;
    struct tm gmt;
    time_t time1 = time(NULL);
    int time_days, time_hours, time_tz;
    int tempnum1, tempnum2;
    struct tm *thetime;
    time_t now;

    gmtime_r(&time1, &gmt);

    time_days = t->tm_yday - gmt.tm_yday;

    if (time_days < -1) {
        tempnum1 = 24;
    }
    else {
        tempnum1 = 1;
    }
    if (tempnum1 < time_days) {
       tempnum2 = -24;
    }
    else {
        tempnum2 = time_days*24;
    }

    time_hours = (tempnum2 + t->tm_hour - gmt.tm_hour);
    time_tz = time_hours * 60 + t->tm_min - gmt.tm_min;

    if (time_tz < 0) {
        sign = '-';
        time_tz = -time_tz;
    }
    else {
        sign = '+';
    }
    
    timezone_string = calloc(1, 7);
    snprintf(timezone_string, 7, " %c%.2d%.2d", sign, time_tz / 60, time_tz % 60);

    now = time(NULL);

    thetime = localtime(&now);
    strftime (buffer, len-7, "%d/%b/%Y:%H:%M:%S", thetime);
    strcat(buffer, timezone_string);

    return 1;
}
#endif
Jack Moffitt's avatar
Jack Moffitt committed
95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
/* 
** ADDR USER AUTH DATE REQUEST CODE BYTES REFERER AGENT [TIME]
**
** ADDR = client->con->ip
** USER = -      
**      we should do this for real once we support authentication
** AUTH = -
** DATE = _make_date(client->con->con_time)
** REQUEST = build from client->parser
** CODE = client->respcode
** BYTES = client->con->sent_bytes
** REFERER = get from client->parser
** AGENT = get from client->parser
** TIME = timing_get_time() - client->con->con_time
*/
void logging_access(client_t *client)
{
112 113
    char datebuf[128];
    char reqbuf[1024];
114
    struct tm thetime;
115 116
    time_t now;
    time_t stayed;
117
    char *referrer, *user_agent;
118 119 120

    now = time(NULL);

121
	localtime_r (&now, &thetime);
122
    /* build the data */
123 124 125 126
#ifdef _WIN32
	memset(datebuf, '\000', sizeof(datebuf));
	get_clf_time(datebuf, sizeof(datebuf)-1, &thetime);
#else
127
    strftime (datebuf, sizeof(datebuf), LOGGING_FORMAT_CLF, &thetime);
128
#endif
129
    /* build the request */
130 131 132 133 134
    snprintf (reqbuf, sizeof(reqbuf), "%s %s %s/%s",
            httpp_getvar (client->parser, HTTPP_VAR_REQ_TYPE),
            httpp_getvar (client->parser, HTTPP_VAR_URI),
            httpp_getvar (client->parser, HTTPP_VAR_PROTOCOL),
            httpp_getvar (client->parser, HTTPP_VAR_VERSION));
135 136 137

    stayed = now - client->con->con_time;

138 139 140 141 142 143 144 145 146
    referrer = httpp_getvar (client->parser, "referer");
    if (referrer == NULL)
        referrer = "-";

    user_agent = httpp_getvar (client->parser, "user-agent");
    if (user_agent == NULL)
        user_agent = "-";

    log_write_direct (accesslog, "%s - - [%s] \"%s\" %d %lld \"%s\" \"%s\" %u",
147 148 149 150 151
             client->con->ip,
             datebuf,
             reqbuf,
             client->respcode,
             client->con->sent_bytes,
152 153 154
             referrer,
             user_agent,
             stayed);
Jack Moffitt's avatar
Jack Moffitt committed
155 156 157 158
}



159
void restart_logging (ice_config_t *config)
160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177
{
    if (strcmp (config->error_log, "-"))
    {
        char fn_error[FILENAME_MAX];
        snprintf (fn_error, FILENAME_MAX, "%s%s%s", config->log_dir, PATH_SEPARATOR, config->error_log);
        log_set_filename (errorlog, fn_error);
        log_set_level (errorlog, config->loglevel);
        log_reopen (errorlog);
    }

    if (strcmp (config->access_log, "-"))
    {
        char fn_error[FILENAME_MAX];
        snprintf (fn_error, FILENAME_MAX, "%s%s%s", config->log_dir, PATH_SEPARATOR, config->access_log);
        log_set_filename (accesslog, fn_error);
        log_reopen (accesslog);
    }
}