2 * Copyright (C) 1996-2018 The Squid Software Foundation and contributors
4 * Squid software is distributed under GPLv2+ license and includes
5 * contributions from numerous individuals and organizations.
6 * Please see the COPYING and CONTRIBUTORS files for details.
9 #ifndef SQUID_SRC_LOGTAGS_H
10 #define SQUID_SRC_LOGTAGS_H
12 #include "CollapsingHistory.h"
14 /** Squid transaction result code/tag set.
16 * These codes indicate how the request was received
17 * and some details about its processing pathway.
19 * see also http://wiki.squid-cache.org/SquidFaq/SquidLogs#Squid_result_codes
20 * for details on particular components.
26 LOG_TCP_REFRESH_UNMODIFIED
, // refresh from origin revalidated existing entry
27 LOG_TCP_REFRESH_FAIL_OLD
, // refresh from origin failed, stale reply sent
28 LOG_TCP_REFRESH_FAIL_ERR
, // refresh from origin failed, error forwarded
29 LOG_TCP_REFRESH_MODIFIED
, // refresh from origin replaced existing entry
30 LOG_TCP_REFRESH
, // refresh from origin started, but still pending
31 LOG_TCP_CLIENT_REFRESH_MISS
,
34 LOG_TCP_SWAPFAIL_MISS
,
41 LOG_TCP_TUNNEL
, // a binary tunnel was established for this transaction
55 explicit LogTags(const LogTags_ot t
) { update(t
); }
57 void update(const LogTags_ot t
);
59 /// compute the status access.log field
60 const char *c_str() const;
62 /// determine if the log tag code indicates a cache HIT
63 bool isTcpHit() const;
65 /// Things that may happen to a transaction while it is being
66 /// processed according to its LOG_* category. Logged as _SUFFIX(es).
67 /// Unlike LOG_* categories, these flags may not be mutually exclusive.
70 Errors() : ignored(false), timedout(false), aborted(false) {}
72 bool ignored
; ///< _IGNORED: the response was not used for anything
73 bool timedout
; ///< _TIMEDOUT: terminated due to a lifetime or I/O timeout
74 bool aborted
; ///< _ABORTED: other abnormal termination (e.g., I/O error)
78 /// list of string representations for LogTags_ot
79 static const char *Str_
[];
81 public: // XXX: only until client_db.cc stats are redesigned.
83 /// a set of client protocol, cache use, and other transaction outcome tags
84 LogTags_ot oldType
= LOG_TAG_NONE
;
85 /// controls CF tag presence
86 CollapsingHistory collapsingHistory
;
89 /// iterator for LogTags_ot enumeration
90 inline LogTags_ot
&operator++ (LogTags_ot
&aLogType
)
92 int tmp
= (int)aLogType
;
93 aLogType
= (LogTags_ot
)(++tmp
);