1 #ifndef _SQUID_FMT_BYTECODE_H
2 #define _SQUID_FMT_BYTECODE_H
5 * Squid configuration allows users to define custom formats in
11 * These enumerations and classes define the API for parsing of
12 * format directives to define these patterns. Along with output
13 * functionality to produce formatted buffers.
20 * Bytecodes for the configureable format stuff
25 /* arbitrary string between tokens */
28 /* client TCP connection remote end details */
29 LFT_CLIENT_IP_ADDRESS
,
34 /* client TCP connection local end details */
36 LFT_CLIENT_LOCAL_PORT
,
37 /*LFT_CLIENT_LOCAL_FQDN, (rDNS) */
39 LFT_CLIENT_LOCAL_NFMARK
,
41 /* client connection local squid.conf details */
42 LFT_LOCAL_LISTENING_IP
,
43 LFT_LOCAL_LISTENING_PORT
,
44 /*LFT_LOCAL_LISTENING_NAME, (myportname) */
46 /* server TCP connection remote end details */
47 LFT_SERVER_IP_ADDRESS
,
48 LFT_SERVER_FQDN_OR_PEER_NAME
,
51 /* server TCP connection local end details */
53 LFT_SERVER_LOCAL_IP_OLD_27
,
54 LFT_SERVER_LOCAL_PORT
,
56 LFT_SERVER_LOCAL_NFMARK
,
58 /* original Request-Line details recieved from client */
59 LFT_CLIENT_REQ_METHOD
,
61 LFT_CLIENT_REQ_URLDOMAIN
,
62 LFT_CLIENT_REQ_URLPATH
,
63 /* LFT_CLIENT_REQ_QUERY, */
64 LFT_CLIENT_REQ_VERSION
,
66 /* Request-Line details recieved from client (legacy, filtered) */
69 LFT_REQUEST_URLPATH_OLD_31
,
70 /*LFT_REQUEST_QUERY, */
71 LFT_REQUEST_VERSION_OLD_2X
,
74 /* request header details pre-adaptation */
76 LFT_REQUEST_HEADER_ELEM
,
77 LFT_REQUEST_ALL_HEADERS
,
79 /* request header details post-adaptation */
80 LFT_ADAPTED_REQUEST_HEADER
,
81 LFT_ADAPTED_REQUEST_HEADER_ELEM
,
82 LFT_ADAPTED_REQUEST_ALL_HEADERS
,
84 /* Request-Line details sent to the server/peer */
85 LFT_SERVER_REQ_METHOD
,
87 LFT_SERVER_REQ_URLPATH
,
88 /*LFT_SERVER_REQ_QUERY, */
89 LFT_SERVER_REQ_VERSION
,
91 /* request meta details */
92 LFT_CLIENT_REQUEST_SIZE_TOTAL
,
93 LFT_CLIENT_REQUEST_SIZE_HEADERS
,
94 /*LFT_REQUEST_SIZE_BODY, */
95 /*LFT_REQUEST_SIZE_BODY_NO_TE, */
97 /* original Status-Line details recieved from server */
100 /* Status-Line details sent to the client */
103 /* response Status-Line details (legacy, filtered) */
104 LFT_HTTP_SENT_STATUS_CODE_OLD_30
,
105 LFT_HTTP_SENT_STATUS_CODE
,
106 LFT_HTTP_RECEIVED_STATUS_CODE
,
107 /*LFT_HTTP_STATUS, */
108 LFT_HTTP_BODY_BYTES_READ
,
110 /* response header details pre-adaptation */
112 LFT_REPLY_HEADER_ELEM
,
113 LFT_REPLY_ALL_HEADERS
,
115 /* response header details post-adaptation */
116 /* LFT_ADAPTED_REPLY_HEADER, */
117 /* LFT_ADAPTED_REPLY_HEADER_ELEM, */
118 /* LFT_ADAPTED_REPLY_ALL_HEADERS, */
120 /* response meta details */
121 LFT_ADAPTED_REPLY_SIZE_TOTAL
,
122 LFT_REPLY_HIGHOFFSET
,
123 LFT_REPLY_OBJECTSIZE
,
124 LFT_ADAPTED_REPLY_SIZE_HEADERS
,
125 /*LFT_REPLY_SIZE_BODY, */
126 /*LFT_REPLY_SIZE_BODY_NO_TE, */
128 LFT_CLIENT_IO_SIZE_TOTAL
,
130 /* client credentials */
131 LFT_USER_NAME
, /* any source will do */
135 /*LFT_USER_SCHEME, */
137 /* LFT_USER_SSL_CERT, */
139 /* global time details */
140 LFT_TIME_SECONDS_SINCE_EPOCH
,
144 LFT_TIME_START
, // the time the master transaction started
146 /* processing time details */
147 LFT_TIME_TO_HANDLE_REQUEST
,
148 LFT_PEER_RESPONSE_TIME
,
149 LFT_TOTAL_SERVER_SIDE_RESPONSE_TIME
,
152 /* Squid internal processing details */
155 LFT_SQUID_ERROR_DETAIL
,
165 LFT_ADAPTATION_SUM_XACT_TIMES
,
166 LFT_ADAPTATION_ALL_XACT_TIMES
,
167 LFT_ADAPTATION_LAST_HEADER
,
168 LFT_ADAPTATION_LAST_HEADER_ELEM
,
169 LFT_ADAPTATION_LAST_ALL_HEADERS
,
178 LFT_ICAP_REQUEST_URI
,
179 LFT_ICAP_REQUEST_METHOD
,
182 LFT_ICAP_BODY_BYTES_READ
,
185 LFT_ICAP_REQ_HEADER_ELEM
,
186 LFT_ICAP_REQ_ALL_HEADERS
,
189 LFT_ICAP_REP_HEADER_ELEM
,
190 LFT_ICAP_REP_ALL_HEADERS
,
192 LFT_ICAP_TR_RESPONSE_TIME
,
195 LFT_ICAP_STATUS_CODE
,
201 LFT_SSL_USER_CERT_SUBJECT
,
202 LFT_SSL_USER_CERT_ISSUER
,
206 LFT_PERCENT
/* special string cases for escaped chars */
209 /// Quoting style for a format output.
218 } // namespace Format
220 #endif /* _SQUID_FMT_BYTECODE_H */