3
* $Id: store_log.cc,v 1.28 2003/07/14 14:16:02 robertc Exp $
5
* DEBUG: section 20 Storage Manager Logging Functions
6
* AUTHOR: Duane Wessels
8
* SQUID Web Proxy Cache http://www.squid-cache.org/
9
* ----------------------------------------------------------
11
* Squid is the result of efforts by numerous individuals from
12
* the Internet community; see the CONTRIBUTORS file for full
13
* details. Many organizations have provided support for Squid's
14
* development; see the SPONSORS file for full details. Squid is
15
* Copyrighted (C) 2001 by the Regents of the University of
16
* California; see the COPYRIGHT file for full details. Squid
17
* incorporates software developed and/or copyrighted by other
18
* sources; see the CREDITS file for full details.
20
* This program is free software; you can redistribute it and/or modify
21
* it under the terms of the GNU General Public License as published by
22
* the Free Software Foundation; either version 2 of the License, or
23
* (at your option) any later version.
25
* This program is distributed in the hope that it will be useful,
26
* but WITHOUT ANY WARRANTY; without even the implied warranty of
27
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
28
* GNU General Public License for more details.
30
* You should have received a copy of the GNU General Public License
31
* along with this program; if not, write to the Free Software
32
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
38
#include "MemObject.h"
39
#include "HttpReply.h"
41
static const char *storeLogTags[] =
50
static Logfile *storelog = NULL;
53
storeLog(int tag, const StoreEntry * e)
55
MemObject *mem = e->mem_obj;
56
HttpReply const *reply;
63
if (EBIT_TEST(e->flags, ENTRY_DONT_LOG))
69
if (mem->log_url == NULL) {
70
debug(20, 1) ("storeLog: NULL log_url for %s\n", mem->url);
72
mem->log_url = xstrdup(mem->url);
75
reply = e->getReply();
77
* XXX Ok, where should we print the dir number here?
78
* Because if we print it before the swap file number, it'll break
79
* the existing log format.
81
logfilePrintf(storelog, "%9d.%03d %-7s %02d %08X %s %4d %9d %9d %9d %s %d/%d %s %s\n",
82
(int) current_time.tv_sec,
83
(int) current_time.tv_usec / 1000,
90
(int) reply->last_modified,
92
reply->content_type.size() ? reply->content_type.buf() : "unknown",
93
reply->content_length,
95
RequestMethodStr[mem->method],
98
/* no mem object. Most RELEASE cases */
99
logfilePrintf(storelog, "%9d.%03d %-7s %02d %08X %s ? ? ? ? ?/? ?/? ? ?\n",
100
(int) current_time.tv_sec,
101
(int) current_time.tv_usec / 1000,
112
if (NULL == storelog)
115
logfileRotate(storelog);
121
if (NULL == storelog)
124
logfileClose(storelog);
132
if (strcmp(Config.Log.store, "none") == 0) {
133
debug(20, 1) ("Store logging disabled\n");
137
storelog = logfileOpen(Config.Log.store, 0, 1);