]> git.ipfire.org Git - thirdparty/squid.git/blob - src/htcp.h
Merge from trunk
[thirdparty/squid.git] / src / htcp.h
1 /*
2 * SQUID Web Proxy Cache http://www.squid-cache.org/
3 * ----------------------------------------------------------
4 *
5 * Squid is the result of efforts by numerous individuals from
6 * the Internet community; see the CONTRIBUTORS file for full
7 * details. Many organizations have provided support for Squid's
8 * development; see the SPONSORS file for full details. Squid is
9 * Copyrighted (C) 2001 by the Regents of the University of
10 * California; see the COPYRIGHT file for full details. Squid
11 * incorporates software developed and/or copyrighted by other
12 * sources; see the CREDITS file for full details.
13 *
14 * This program is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation; either version 2 of the License, or
17 * (at your option) any later version.
18 *
19 * This program is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * You should have received a copy of the GNU General Public License
25 * along with this program; if not, write to the Free Software
26 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
27 *
28 */
29
30 #ifndef SQUID_HTCP_H
31 #define SQUID_HTCP_H
32
33 #if USE_HTCP
34
35 #include "HttpHeader.h"
36 #include "http/forward.h"
37 #include "ip/forward.h"
38
39 /// \ingroup ServerProtocolHTCP
40 class HtcpReplyData
41 {
42
43 public:
44 HtcpReplyData();
45 int hit;
46 HttpHeader hdr;
47 uint32_t msg_id;
48 double version;
49
50 struct cto_t {
51 /* cache-to-origin */
52 double rtt;
53 int samp;
54 int hops;
55 } cto;
56 };
57
58 /// \ingroup ServerProtocolHTCP
59 void neighborsHtcpReply(const cache_key *, HtcpReplyData *, const Ip::Address &);
60
61 /// \ingroup ServerProtocolHTCP
62 void htcpOpenPorts(void);
63
64 /**
65 * \ingroup ServerProtocolHTCP
66 *
67 * Generate and Send an HTCP query to the specified peer.
68 *
69 * \param e
70 * \param req
71 * \param p
72 * \retval 1 Successfully sent request.
73 * \retval 0 Unable to send request at this time. HTCP may be shutting down or starting up.
74 * Don't wait for a reply or count in stats as sent.
75 * \retval -1 Error sending request.
76 */
77 int htcpQuery(StoreEntry * e, HttpRequest * req, CachePeer * p);
78
79 /// \ingroup ServerProtocolHTCP
80 void htcpClear(StoreEntry * e, const char *uri, HttpRequest * req, const HttpRequestMethod &method, CachePeer * p, htcp_clr_reason reason);
81
82 /// \ingroup ServerProtocolHTCP
83 void htcpSocketShutdown(void);
84
85 /// \ingroup ServerProtocolHTCP
86 void htcpClosePorts(void);
87
88 #endif /* USE_HTCP */
89
90 #endif /* SQUID_HTCP_H */