Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 1 | /* |
Willy Tarreau | 5b4c2b5 | 2009-10-03 11:21:53 +0200 | [diff] [blame] | 2 | * include/types/proxy.h |
| 3 | * This file defines everything related to proxies. |
| 4 | * |
Willy Tarreau | deb9ed8 | 2010-01-03 21:03:22 +0100 | [diff] [blame] | 5 | * Copyright (C) 2000-2010 Willy Tarreau - w@1wt.eu |
Willy Tarreau | 5b4c2b5 | 2009-10-03 11:21:53 +0200 | [diff] [blame] | 6 | * |
| 7 | * This library is free software; you can redistribute it and/or |
| 8 | * modify it under the terms of the GNU Lesser General Public |
| 9 | * License as published by the Free Software Foundation, version 2.1 |
| 10 | * exclusively. |
| 11 | * |
| 12 | * This library is distributed in the hope that it will be useful, |
| 13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 15 | * Lesser General Public License for more details. |
| 16 | * |
| 17 | * You should have received a copy of the GNU Lesser General Public |
| 18 | * License along with this library; if not, write to the Free Software |
| 19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
| 20 | */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 21 | |
| 22 | #ifndef _TYPES_PROXY_H |
| 23 | #define _TYPES_PROXY_H |
| 24 | |
Willy Tarreau | 7d67768 | 2006-10-15 23:18:47 +0200 | [diff] [blame] | 25 | #include <sys/types.h> |
| 26 | #include <sys/socket.h> |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 27 | #include <netinet/in.h> |
| 28 | #include <arpa/inet.h> |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 29 | |
Willy Tarreau | 2dd0d47 | 2006-06-29 17:53:05 +0200 | [diff] [blame] | 30 | #include <common/appsession.h> |
Willy Tarreau | e3ba5f0 | 2006-06-29 18:54:54 +0200 | [diff] [blame] | 31 | #include <common/config.h> |
Willy Tarreau | 2dd0d47 | 2006-06-29 17:53:05 +0200 | [diff] [blame] | 32 | #include <common/mini-clist.h> |
| 33 | #include <common/regex.h> |
Willy Tarreau | 51041c7 | 2007-09-09 21:56:53 +0200 | [diff] [blame] | 34 | #include <common/sessionhash.h> |
Willy Tarreau | a8cff1d | 2007-04-09 16:10:57 +0200 | [diff] [blame] | 35 | #include <common/tools.h> |
Willy Tarreau | 45cb4fb | 2009-10-26 21:10:04 +0100 | [diff] [blame] | 36 | #include <eb32tree.h> |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 37 | |
Willy Tarreau | eb0c614 | 2007-05-07 00:53:22 +0200 | [diff] [blame] | 38 | #include <types/acl.h> |
Emeric Brun | b982a3d | 2010-01-04 15:45:53 +0100 | [diff] [blame] | 39 | #include <types/pattern.h> |
Willy Tarreau | 5b4c2b5 | 2009-10-03 11:21:53 +0200 | [diff] [blame] | 40 | #include <types/backend.h> |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 41 | #include <types/buffers.h> |
Krzysztof Piotr Oledzki | 052d4fd | 2009-10-04 14:52:57 +0200 | [diff] [blame] | 42 | #include <types/counters.h> |
Willy Tarreau | 7f062c4 | 2009-03-05 18:43:00 +0100 | [diff] [blame] | 43 | #include <types/freq_ctr.h> |
Willy Tarreau | 0f77253 | 2006-12-23 20:51:41 +0100 | [diff] [blame] | 44 | #include <types/httperr.h> |
Robert Tsai | 81ae195 | 2007-12-05 10:47:29 +0100 | [diff] [blame] | 45 | #include <types/log.h> |
Willy Tarreau | dd81598 | 2007-10-16 12:25:14 +0200 | [diff] [blame] | 46 | #include <types/protocols.h> |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 47 | #include <types/session.h> |
| 48 | #include <types/server.h> |
Emeric Brun | b982a3d | 2010-01-04 15:45:53 +0100 | [diff] [blame] | 49 | #include <types/stick_table.h> |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 50 | |
| 51 | /* values for proxy->state */ |
| 52 | #define PR_STNEW 0 |
| 53 | #define PR_STIDLE 1 |
| 54 | #define PR_STRUN 2 |
| 55 | #define PR_STSTOPPED 3 |
| 56 | #define PR_STPAUSED 4 |
| 57 | #define PR_STERROR 5 |
| 58 | |
| 59 | /* values for proxy->mode */ |
| 60 | #define PR_MODE_TCP 0 |
| 61 | #define PR_MODE_HTTP 1 |
| 62 | #define PR_MODE_HEALTH 2 |
| 63 | |
Willy Tarreau | 977b8e4 | 2006-12-29 14:19:17 +0100 | [diff] [blame] | 64 | /* flag values for proxy->cap. This is a bitmask of capabilities supported by the proxy */ |
| 65 | #define PR_CAP_NONE 0x0000 |
| 66 | #define PR_CAP_FE 0x0001 |
| 67 | #define PR_CAP_BE 0x0002 |
| 68 | #define PR_CAP_RS 0x0004 |
| 69 | #define PR_CAP_LISTEN (PR_CAP_FE|PR_CAP_BE|PR_CAP_RS) |
| 70 | |
Willy Tarreau | 3168223 | 2007-11-29 15:38:04 +0100 | [diff] [blame] | 71 | /* bits for proxy->options */ |
| 72 | #define PR_O_REDISP 0x00000001 /* allow reconnection to dispatch in case of errors */ |
| 73 | #define PR_O_TRANSP 0x00000002 /* transparent mode : use original DEST as dispatch */ |
| 74 | #define PR_O_COOK_RW 0x00000004 /* rewrite all direct cookies with the right serverid */ |
| 75 | #define PR_O_COOK_IND 0x00000008 /* keep only indirect cookies */ |
| 76 | #define PR_O_COOK_INS 0x00000010 /* insert cookies when not accessing a server directly */ |
| 77 | #define PR_O_COOK_PFX 0x00000020 /* rewrite all cookies by prefixing the right serverid */ |
| 78 | #define PR_O_COOK_ANY (PR_O_COOK_RW | PR_O_COOK_IND | PR_O_COOK_INS | PR_O_COOK_PFX) |
| 79 | #define PR_O_SMTP_CHK 0x00000040 /* use SMTP EHLO check for server health - pvandijk@vision6.com.au */ |
| 80 | #define PR_O_KEEPALIVE 0x00000080 /* follow keep-alive sessions */ |
| 81 | #define PR_O_FWDFOR 0x00000100 /* insert x-forwarded-for with client address */ |
| 82 | #define PR_O_BIND_SRC 0x00000200 /* bind to a specific source address when connect()ing */ |
| 83 | #define PR_O_NULLNOLOG 0x00000400 /* a connect without request will not be logged */ |
| 84 | #define PR_O_COOK_NOC 0x00000800 /* add a 'Cache-control' header with the cookie */ |
| 85 | #define PR_O_COOK_POST 0x00001000 /* don't insert cookies for requests other than a POST */ |
| 86 | #define PR_O_HTTP_CHK 0x00002000 /* use HTTP 'OPTIONS' method to check server health */ |
| 87 | #define PR_O_PERSIST 0x00004000 /* server persistence stays effective even when server is down */ |
| 88 | #define PR_O_LOGASAP 0x00008000 /* log as soon as possible, without waiting for the session to complete */ |
| 89 | #define PR_O_HTTP_CLOSE 0x00010000 /* force 'connection: close' in both directions */ |
| 90 | #define PR_O_CHK_CACHE 0x00020000 /* require examination of cacheability of the 'set-cookie' field */ |
| 91 | #define PR_O_TCP_CLI_KA 0x00040000 /* enable TCP keep-alive on client-side sessions */ |
| 92 | #define PR_O_TCP_SRV_KA 0x00080000 /* enable TCP keep-alive on server-side sessions */ |
| 93 | #define PR_O_USE_ALL_BK 0x00100000 /* load-balance between backup servers */ |
| 94 | #define PR_O_FORCE_CLO 0x00200000 /* enforce the connection close immediately after server response */ |
| 95 | #define PR_O_TCP_NOLING 0x00400000 /* disable lingering on client and server connections */ |
| 96 | #define PR_O_ABRT_CLOSE 0x00800000 /* immediately abort request when client closes */ |
Willy Tarreau | 3168223 | 2007-11-29 15:38:04 +0100 | [diff] [blame] | 97 | |
| 98 | /* TPXY: exclusive values */ |
Willy Tarreau | 090466c | 2009-09-07 11:51:47 +0200 | [diff] [blame] | 99 | #define PR_O_TPXY_ADDR 0x01000000 /* bind to this non-local address when connect()ing */ |
| 100 | #define PR_O_TPXY_CIP 0x02000000 /* bind to the client's IP address when connect()ing */ |
| 101 | #define PR_O_TPXY_CLI 0x03000000 /* bind to the client's IP+port when connect()ing */ |
| 102 | #define PR_O_TPXY_DYN 0x04000000 /* bind to a dynamically computed non-local address */ |
| 103 | #define PR_O_TPXY_MASK 0x07000000 /* bind to a non-local address when connect()ing */ |
Willy Tarreau | 3168223 | 2007-11-29 15:38:04 +0100 | [diff] [blame] | 104 | |
Willy Tarreau | b608feb | 2010-01-02 22:47:18 +0100 | [diff] [blame] | 105 | #define PR_O_SERVER_CLO 0x08000000 /* option http-server-close */ |
Willy Tarreau | 3168223 | 2007-11-29 15:38:04 +0100 | [diff] [blame] | 106 | #define PR_O_CONTSTATS 0x10000000 /* continous counters */ |
Alexandre Cassen | 5eb1a90 | 2007-11-29 15:43:32 +0100 | [diff] [blame] | 107 | #define PR_O_HTTP_PROXY 0x20000000 /* Enable session to use HTTP proxy operations */ |
Willy Tarreau | 48494c0 | 2007-11-30 10:41:39 +0100 | [diff] [blame] | 108 | #define PR_O_DISABLE404 0x40000000 /* Disable a server on a 404 response to a health-check */ |
Maik Broemme | 2850cb4 | 2009-04-17 18:53:21 +0200 | [diff] [blame] | 109 | #define PR_O_ORGTO 0x80000000 /* insert x-original-to with destination address */ |
Willy Tarreau | 66aa61f | 2009-01-18 21:44:07 +0100 | [diff] [blame] | 110 | |
| 111 | /* bits for proxy->options2 */ |
| 112 | #define PR_O2_SPLIC_REQ 0x00000001 /* transfer requests using linux kernel's splice() */ |
| 113 | #define PR_O2_SPLIC_RTR 0x00000002 /* transfer responses using linux kernel's splice() */ |
| 114 | #define PR_O2_SPLIC_AUT 0x00000004 /* automatically use linux kernel's splice() */ |
| 115 | #define PR_O2_SPLIC_ANY (PR_O2_SPLIC_REQ|PR_O2_SPLIC_RTR|PR_O2_SPLIC_AUT) |
Willy Tarreau | 32a4ec0 | 2009-04-02 11:35:18 +0200 | [diff] [blame] | 116 | #define PR_O2_REQBUG_OK 0x00000008 /* let buggy requests pass through */ |
| 117 | #define PR_O2_RSPBUG_OK 0x00000010 /* let buggy responses pass through */ |
Willy Tarreau | c9bd0cc | 2009-05-10 11:57:02 +0200 | [diff] [blame] | 118 | #define PR_O2_NOLOGNORM 0x00000020 /* don't log normal traffic, only errors and retries */ |
| 119 | #define PR_O2_LOGERRORS 0x00000040 /* log errors and retries at level LOG_ERR */ |
Willy Tarreau | 9ea05a7 | 2009-06-14 12:07:01 +0200 | [diff] [blame] | 120 | #define PR_O2_SMARTACC 0x00000080 /* don't immediately ACK request after accept */ |
Willy Tarreau | d88edf2 | 2009-06-14 15:48:17 +0200 | [diff] [blame] | 121 | #define PR_O2_SMARTCON 0x00000100 /* don't immediately send empty ACK after connect */ |
Emeric Brun | 647caf1 | 2009-06-30 17:57:00 +0200 | [diff] [blame] | 122 | #define PR_O2_RDPC_PRST 0x00000200 /* Actvate rdp cookie analyser */ |
Emeric Brun | 3a058f3 | 2009-06-30 18:26:00 +0200 | [diff] [blame] | 123 | #define PR_O2_CLFLOG 0x00000400 /* log into clf format */ |
Krzysztof Piotr Oledzki | 213014e | 2009-09-27 15:50:02 +0200 | [diff] [blame] | 124 | #define PR_O2_LOGHCHKS 0x00000800 /* log health checks */ |
Willy Tarreau | f27b5ea | 2009-10-03 22:01:18 +0200 | [diff] [blame] | 125 | #define PR_O2_INDEPSTR 0x00001000 /* independant streams, don't update rex on write */ |
Krzysztof Piotr Oledzki | aeebf9b | 2009-10-04 15:43:17 +0200 | [diff] [blame] | 126 | #define PR_O2_SOCKSTAT 0x00002000 /* collect & provide separate statistics for sockets */ |
Cyril Bonté | b21570a | 2009-11-29 20:04:48 +0100 | [diff] [blame] | 127 | |
| 128 | /* appsession */ |
| 129 | #define PR_O2_AS_REQL 0x00004000 /* learn the session id from the request */ |
| 130 | #define PR_O2_AS_PFX 0x00008000 /* match on the cookie prefix */ |
| 131 | |
| 132 | /* Encoding of appsession cookie matching modes : 2 possible values => 1 bit */ |
| 133 | #define PR_O2_AS_M_PP 0x00000000 /* path-parameters mode (the default mode) */ |
| 134 | #define PR_O2_AS_M_QS 0x00010000 /* query-string mode */ |
| 135 | #define PR_O2_AS_M_ANY 0x00010000 /* mask covering all PR_O2_AS_M_* values */ |
Willy Tarreau | 3168223 | 2007-11-29 15:38:04 +0100 | [diff] [blame] | 136 | |
Hervé COMMOWICK | 698ae00 | 2010-01-12 09:25:13 +0100 | [diff] [blame] | 137 | #define PR_O2_MYSQL_CHK 0x00020000 /* use MYSQL check for server health */ |
Willy Tarreau | 88d349d | 2010-01-25 12:15:43 +0100 | [diff] [blame] | 138 | #define PR_O2_USE_PXHDR 0x00040000 /* use Proxy-Connection for proxy requests */ |
Willy Tarreau | ef78104 | 2010-01-27 11:53:01 +0100 | [diff] [blame] | 139 | #define PR_O2_CHK_SNDST 0x00080000 /* send the state of each server along with HTTP health checks */ |
Willy Tarreau | 07a5490 | 2010-03-29 18:33:29 +0200 | [diff] [blame] | 140 | #define PR_O2_SSL3_CHK 0x00100000 /* use SSLv3 CLIENT_HELLO packets for server health */ |
Willy Tarreau | 8a8e1d9 | 2010-04-05 16:15:16 +0200 | [diff] [blame] | 141 | #define PR_O2_FAKE_KA 0x00200000 /* pretend we do keep-alive with server eventhough we close */ |
Gabor Lekeny | b4c81e4 | 2010-09-29 18:17:05 +0200 | [diff] [blame] | 142 | #define PR_O2_LDAP_CHK 0x00400000 /* use LDAP check for server health */ |
Willy Tarreau | bd74154 | 2010-03-16 18:46:54 +0100 | [diff] [blame] | 143 | |
| 144 | #define PR_O2_EXP_NONE 0x00000000 /* http-check : no expect rule */ |
| 145 | #define PR_O2_EXP_STS 0x00800000 /* http-check expect status */ |
| 146 | #define PR_O2_EXP_RSTS 0x01000000 /* http-check expect rstatus */ |
| 147 | #define PR_O2_EXP_STR 0x01800000 /* http-check expect string */ |
| 148 | #define PR_O2_EXP_RSTR 0x02000000 /* http-check expect rstring */ |
| 149 | #define PR_O2_EXP_TYPE 0x03800000 /* mask for http-check expect type */ |
| 150 | #define PR_O2_EXP_INV 0x04000000 /* http-check expect !<rule> */ |
Willy Tarreau | ba4c5be | 2010-10-23 12:46:42 +0200 | [diff] [blame^] | 151 | #define PR_O2_COOK_PSV 0x08000000 /* cookie ... preserve */ |
Emeric Brun | b982a3d | 2010-01-04 15:45:53 +0100 | [diff] [blame] | 152 | /* end of proxy->options2 */ |
| 153 | |
| 154 | /* bits for sticking rules */ |
| 155 | #define STK_IS_MATCH 0x00000001 /* match on request fetch */ |
| 156 | #define STK_IS_STORE 0x00000002 /* store on request fetch */ |
| 157 | #define STK_ON_RSP 0x00000004 /* store on response fetch */ |
Hervé COMMOWICK | 698ae00 | 2010-01-12 09:25:13 +0100 | [diff] [blame] | 158 | |
Willy Tarreau | f073a83 | 2009-03-01 23:21:47 +0100 | [diff] [blame] | 159 | struct error_snapshot { |
| 160 | struct timeval when; /* date of this event, (tv_sec == 0) means "never" */ |
| 161 | unsigned int len; /* original length of the last invalid request/response */ |
| 162 | unsigned int pos; /* position of the first invalid character */ |
| 163 | unsigned int sid; /* ID of the faulty session */ |
| 164 | struct server *srv; /* server associated with the error (or NULL) */ |
| 165 | struct proxy *oe; /* other end = frontend or backend involved */ |
| 166 | struct sockaddr_storage src; /* client's address */ |
| 167 | char buf[BUFSIZE]; /* copy of the beginning of the message */ |
| 168 | }; |
| 169 | |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 170 | struct proxy { |
| 171 | struct listener *listen; /* the listen addresses and sockets */ |
| 172 | struct in_addr mon_net, mon_mask; /* don't forward connections from this net (network order) FIXME: should support IPv6 */ |
| 173 | int state; /* proxy state */ |
Willy Tarreau | 35d66b0 | 2007-01-02 00:28:21 +0100 | [diff] [blame] | 174 | int options; /* PR_O_REDISP, PR_O_TRANSP, ... */ |
Willy Tarreau | 66aa61f | 2009-01-18 21:44:07 +0100 | [diff] [blame] | 175 | int options2; /* PR_O2_* */ |
Willy Tarreau | c1a2167 | 2009-08-16 22:37:44 +0200 | [diff] [blame] | 176 | unsigned int fe_req_ana, be_req_ana; /* bitmap of common request protocol analysers for the frontend and backend */ |
Willy Tarreau | 4e5b828 | 2009-08-16 22:57:50 +0200 | [diff] [blame] | 177 | unsigned int fe_rsp_ana, be_rsp_ana; /* bitmap of common response protocol analysers for the frontend and backend */ |
Willy Tarreau | 35d66b0 | 2007-01-02 00:28:21 +0100 | [diff] [blame] | 178 | int mode; /* mode = PR_MODE_TCP, PR_MODE_HTTP or PR_MODE_HEALTH */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 179 | struct sockaddr_in dispatch_addr; /* the default address to connect to */ |
Willy Tarreau | 5fdfb91 | 2007-01-01 23:11:07 +0100 | [diff] [blame] | 180 | union { |
| 181 | struct proxy *be; /* default backend, or NULL if none set */ |
| 182 | char *name; /* default backend name during config parse */ |
| 183 | } defbe; |
Willy Tarreau | eb0c614 | 2007-05-07 00:53:22 +0200 | [diff] [blame] | 184 | struct list acl; /* ACL declared on this proxy */ |
Krzysztof Piotr Oledzki | 59bb218 | 2010-01-29 17:58:21 +0100 | [diff] [blame] | 185 | struct list req_acl; /* request ACL: allow/deny/http-auth */ |
Willy Tarreau | 5c8e3e0 | 2007-05-07 00:58:25 +0200 | [diff] [blame] | 186 | struct list block_cond; /* early blocking conditions (chained) */ |
Willy Tarreau | b463dfb | 2008-06-07 23:08:56 +0200 | [diff] [blame] | 187 | struct list redirect_rules; /* content redirecting rules (chained) */ |
Willy Tarreau | 55ea757 | 2007-06-17 19:56:27 +0200 | [diff] [blame] | 188 | struct list switching_rules; /* content switching rules (chained) */ |
Cyril Bonté | 47fdd8e | 2010-04-25 00:00:51 +0200 | [diff] [blame] | 189 | struct list persist_rules; /* 'force-persist' and 'ignore-persist' rules (chained) */ |
Emeric Brun | b982a3d | 2010-01-04 15:45:53 +0100 | [diff] [blame] | 190 | struct list sticking_rules; /* content sticking rules (chained) */ |
| 191 | struct list storersp_rules; /* content store response rules (chained) */ |
Willy Tarreau | b686644 | 2008-07-14 23:54:42 +0200 | [diff] [blame] | 192 | struct { /* TCP request processing */ |
Willy Tarreau | c7e961e | 2008-08-17 17:13:47 +0200 | [diff] [blame] | 193 | unsigned int inspect_delay; /* inspection delay */ |
Willy Tarreau | b686644 | 2008-07-14 23:54:42 +0200 | [diff] [blame] | 194 | struct list inspect_rules; /* inspection rules */ |
Willy Tarreau | ab78619 | 2010-05-23 22:39:25 +0200 | [diff] [blame] | 195 | struct list l4_rules; /* layer4 rules */ |
Willy Tarreau | b686644 | 2008-07-14 23:54:42 +0200 | [diff] [blame] | 196 | } tcp_req; |
Willy Tarreau | a9fb083 | 2009-07-10 20:53:53 +0200 | [diff] [blame] | 197 | int acl_requires; /* Elements required to satisfy all ACLs (ACL_USE_*) */ |
Krzysztof Piotr Oledzki | c6df066 | 2010-01-05 16:38:49 +0100 | [diff] [blame] | 198 | struct server *srv, defsrv; /* known servers; default server configuration */ |
Willy Tarreau | b625a08 | 2007-11-26 01:15:43 +0100 | [diff] [blame] | 199 | int srv_act, srv_bck; /* # of servers eligible for LB (UP|!checked) AND (enabled+weight!=0) */ |
Willy Tarreau | 5b4c2b5 | 2009-10-03 11:21:53 +0200 | [diff] [blame] | 200 | struct lbprm lbprm; /* load-balancing parameters */ |
Krzysztof Piotr Oledzki | 1acf217 | 2008-05-29 23:03:34 +0200 | [diff] [blame] | 201 | char *cookie_domain; /* domain used to insert the cookie */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 202 | char *cookie_name; /* name of the cookie to look for */ |
| 203 | int cookie_len; /* strlen(cookie_name), computed only once */ |
Willy Tarreau | 3193685 | 2010-10-06 16:59:56 +0200 | [diff] [blame] | 204 | unsigned int cookie_maxidle; /* max idle time for this cookie */ |
| 205 | unsigned int cookie_maxlife; /* max life time for this cookie */ |
Emeric Brun | 647caf1 | 2009-06-30 17:57:00 +0200 | [diff] [blame] | 206 | char *rdp_cookie_name; /* name of the RDP cookie to look for */ |
| 207 | int rdp_cookie_len; /* strlen(rdp_cookie_name), computed only once */ |
Willy Tarreau | 0173280 | 2007-11-01 22:48:15 +0100 | [diff] [blame] | 208 | char *url_param_name; /* name of the URL parameter used for hashing */ |
| 209 | int url_param_len; /* strlen(url_param_name), computed only once */ |
matt.farnsworth@nokia.com | 1c2ab96 | 2008-04-14 20:47:37 +0200 | [diff] [blame] | 210 | unsigned url_param_post_limit; /* if checking POST body for URI parameter, max body to wait for */ |
Marek Majkowski | 9c30fc1 | 2008-04-27 23:25:55 +0200 | [diff] [blame] | 211 | int uri_len_limit; /* character limit for uri balancing algorithm */ |
| 212 | int uri_dirs_depth1; /* directories+1 (slashes) limit for uri balancing algorithm */ |
Benoit | affb481 | 2009-03-25 13:02:10 +0100 | [diff] [blame] | 213 | char *hh_name; /* name of the header parameter used for hashing */ |
| 214 | int hh_len; /* strlen(hh_name), computed only once */ |
| 215 | int hh_match_domain; /* toggle use of special match function */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 216 | char *appsession_name; /* name of the cookie to look for */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 217 | int appsession_name_len; /* strlen(appsession_name), computed only once */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 218 | int appsession_len; /* length of the appsession cookie value to be used */ |
Willy Tarreau | 51041c7 | 2007-09-09 21:56:53 +0200 | [diff] [blame] | 219 | struct appsession_hash htbl_proxy; /* Per Proxy hashtable */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 220 | char *capture_name; /* beginning of the name of the cookie to capture */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 221 | int capture_namelen; /* length of the cookie name to match */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 222 | int capture_len; /* length of the string to be captured */ |
| 223 | struct uri_auth *uri_auth; /* if non-NULL, the (list of) per-URI authentications */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 224 | char *monitor_uri; /* a special URI to which we respond with HTTP/200 OK */ |
| 225 | int monitor_uri_len; /* length of the string above. 0 if unused */ |
Willy Tarreau | b80c230 | 2007-11-30 20:51:32 +0100 | [diff] [blame] | 226 | struct list mon_fail_cond; /* list of conditions to fail monitoring requests (chained) */ |
Willy Tarreau | 3a70f94 | 2008-02-15 11:15:34 +0100 | [diff] [blame] | 227 | struct { /* WARNING! check proxy_reset_timeouts() in proxy.h !!! */ |
Willy Tarreau | 0c303ee | 2008-07-07 00:09:58 +0200 | [diff] [blame] | 228 | int client; /* client I/O timeout (in ticks) */ |
| 229 | int tarpit; /* tarpit timeout, defaults to connect if unspecified */ |
| 230 | int queue; /* queue timeout, defaults to connect if unspecified */ |
| 231 | int connect; /* connect timeout (in ticks) */ |
| 232 | int server; /* server I/O timeout (in ticks) */ |
| 233 | int appsession; /* appsession cookie expiration */ |
| 234 | int httpreq; /* maximum time for complete HTTP request */ |
Willy Tarreau | b16a574 | 2010-01-10 14:46:16 +0100 | [diff] [blame] | 235 | int httpka; /* maximum time for a new HTTP request when using keep-alive */ |
Willy Tarreau | 0c303ee | 2008-07-07 00:09:58 +0200 | [diff] [blame] | 236 | int check; /* maximum time for complete check */ |
Willy Tarreau | 1fa3126 | 2007-12-03 00:36:16 +0100 | [diff] [blame] | 237 | } timeout; |
Krzysztof Piotr Oledzki | 48cb2ae | 2009-10-02 22:51:14 +0200 | [diff] [blame] | 238 | char *id, *desc; /* proxy id (name) and description */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 239 | struct list pendconns; /* pending connections with no server assigned yet */ |
Willy Tarreau | ac68c5d | 2009-10-04 23:12:44 +0200 | [diff] [blame] | 240 | int nbpend; /* number of pending connections with no server assigned yet */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 241 | int totpend; /* total number of pending connections on this instance (for stats) */ |
Krzysztof Piotr Oledzki | 052d4fd | 2009-10-04 14:52:57 +0200 | [diff] [blame] | 242 | unsigned int feconn, beconn; /* # of active frontend and backends sessions */ |
Willy Tarreau | d9b587f | 2010-02-26 10:05:55 +0100 | [diff] [blame] | 243 | struct freq_ctr fe_req_per_sec; /* HTTP requests per second on the frontend */ |
Willy Tarreau | b36b424 | 2010-06-04 20:59:39 +0200 | [diff] [blame] | 244 | struct freq_ctr fe_conn_per_sec; /* received connections per second on the frontend */ |
| 245 | struct freq_ctr fe_sess_per_sec; /* accepted sessions per second on the frontend (after tcp rules) */ |
Willy Tarreau | 7f062c4 | 2009-03-05 18:43:00 +0100 | [diff] [blame] | 246 | struct freq_ctr be_sess_per_sec; /* sessions per second on the backend */ |
Willy Tarreau | 8603431 | 2006-12-29 00:10:33 +0100 | [diff] [blame] | 247 | unsigned int maxconn; /* max # of active sessions on the frontend */ |
Willy Tarreau | 13a34bd | 2009-05-10 18:52:49 +0200 | [diff] [blame] | 248 | unsigned int fe_sps_lim; /* limit on new sessions per second on the frontend */ |
Willy Tarreau | 8603431 | 2006-12-29 00:10:33 +0100 | [diff] [blame] | 249 | unsigned int fullconn; /* #conns on backend above which servers are used at full load */ |
Willy Tarreau | 7ac51f6 | 2007-03-25 16:00:04 +0200 | [diff] [blame] | 250 | struct in_addr except_net, except_mask; /* don't x-forward-for for this address. FIXME: should support IPv6 */ |
Maik Broemme | 2850cb4 | 2009-04-17 18:53:21 +0200 | [diff] [blame] | 251 | struct in_addr except_to; /* don't x-original-to for this address. */ |
| 252 | struct in_addr except_mask_to; /* the netmask for except_to. */ |
Ross West | af72a1d | 2008-08-03 10:51:45 +0200 | [diff] [blame] | 253 | char *fwdfor_hdr_name; /* header to use - default: "x-forwarded-for" */ |
| 254 | int fwdfor_hdr_len; /* length of "x-forwarded-for" header */ |
Maik Broemme | 2850cb4 | 2009-04-17 18:53:21 +0200 | [diff] [blame] | 255 | char *orgto_hdr_name; /* header to use - default: "x-original-to" */ |
| 256 | int orgto_hdr_len; /* length of "x-original-to" header */ |
Krzysztof Oledzki | 8513094 | 2007-10-22 16:21:10 +0200 | [diff] [blame] | 257 | |
| 258 | unsigned down_trans; /* up-down transitions */ |
| 259 | unsigned down_time; /* total time the proxy was down */ |
| 260 | time_t last_change; /* last time, when the state was changed */ |
| 261 | |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 262 | int conn_retries; /* maximum number of connect retries */ |
Willy Tarreau | 977b8e4 | 2006-12-29 14:19:17 +0100 | [diff] [blame] | 263 | int cap; /* supported capabilities (PR_CAP_*) */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 264 | struct sockaddr_in source_addr; /* the address to which we want to bind for connect() */ |
Willy Tarreau | 4864c35 | 2008-01-14 16:36:15 +0100 | [diff] [blame] | 265 | #if defined(CONFIG_HAP_CTTPROXY) || defined(CONFIG_HAP_LINUX_TPROXY) |
Willy Tarreau | 77074d5 | 2006-11-12 23:57:19 +0100 | [diff] [blame] | 266 | struct sockaddr_in tproxy_addr; /* non-local address we want to bind to for connect() */ |
Willy Tarreau | bce7088 | 2009-09-07 11:51:47 +0200 | [diff] [blame] | 267 | char *bind_hdr_name; /* bind to this header name if defined */ |
| 268 | int bind_hdr_len; /* length of the name of the header above */ |
| 269 | int bind_hdr_occ; /* occurrence number of header above: >0 = from first, <0 = from end, 0=disabled */ |
Willy Tarreau | 77074d5 | 2006-11-12 23:57:19 +0100 | [diff] [blame] | 270 | #endif |
Willy Tarreau | d53f96b | 2009-02-04 18:46:54 +0100 | [diff] [blame] | 271 | int iface_len; /* bind interface name length */ |
| 272 | char *iface_name; /* bind interface name or NULL */ |
Willy Tarreau | f229eb8 | 2010-06-01 17:14:24 +0200 | [diff] [blame] | 273 | int (*accept)(struct session *s); /* application layer's accept() */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 274 | struct proxy *next; |
Robert Tsai | 81ae195 | 2007-12-05 10:47:29 +0100 | [diff] [blame] | 275 | struct logsrv logsrv1, logsrv2; /* 2 syslog servers */ |
Willy Tarreau | 1c47f85 | 2006-07-09 08:22:27 +0200 | [diff] [blame] | 276 | signed char logfac1, logfac2; /* log facility for both servers. -1 = disabled */ |
| 277 | int loglev1, loglev2; /* log level for each server, 7 by default */ |
Willy Tarreau | f7edefa | 2009-05-10 17:20:05 +0200 | [diff] [blame] | 278 | int minlvl1, minlvl2; /* minimum log level for each server, 0 by default */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 279 | int to_log; /* things to be logged (LW_*) */ |
Willy Tarreau | 0c303ee | 2008-07-07 00:09:58 +0200 | [diff] [blame] | 280 | int stop_time; /* date to stop listening, when stopping != 0 (int ticks) */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 281 | struct hdr_exp *req_exp; /* regular expressions for request headers */ |
| 282 | struct hdr_exp *rsp_exp; /* regular expressions for response headers */ |
| 283 | int nb_req_cap, nb_rsp_cap; /* # of headers to be captured */ |
| 284 | struct cap_hdr *req_cap; /* chained list of request headers to be captured */ |
| 285 | struct cap_hdr *rsp_cap; /* chained list of response headers to be captured */ |
Willy Tarreau | cf7f320 | 2007-05-13 22:46:04 +0200 | [diff] [blame] | 286 | struct pool_head *req_cap_pool, /* pools of pre-allocated char ** used to build the sessions */ |
| 287 | *rsp_cap_pool; |
Willy Tarreau | 1d4154a | 2007-05-13 22:57:02 +0200 | [diff] [blame] | 288 | struct pool_head *hdr_idx_pool; /* pools of pre-allocated int* used for headers indexing */ |
Willy Tarreau | deb9ed8 | 2010-01-03 21:03:22 +0100 | [diff] [blame] | 289 | struct list req_add, rsp_add; /* headers to be added */ |
Willy Tarreau | ac68c5d | 2009-10-04 23:12:44 +0200 | [diff] [blame] | 290 | struct pxcounters counters; /* statistics counters */ |
Emeric Brun | b982a3d | 2010-01-04 15:45:53 +0100 | [diff] [blame] | 291 | |
| 292 | struct stktable table; /* table for storing sticking sessions */ |
| 293 | |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 294 | int grace; /* grace time after stop request */ |
Willy Tarreau | f3c6920 | 2006-07-09 16:42:34 +0200 | [diff] [blame] | 295 | char *check_req; /* HTTP or SSL request to use for PR_O_HTTP_CHK|PR_O_SSL3_CHK */ |
| 296 | int check_len; /* Length of the HTTP or SSL3 request */ |
Willy Tarreau | bd74154 | 2010-03-16 18:46:54 +0100 | [diff] [blame] | 297 | char *expect_str; /* http-check expected content */ |
| 298 | regex_t *expect_regex; /* http-check expected content */ |
Willy Tarreau | 0f77253 | 2006-12-23 20:51:41 +0100 | [diff] [blame] | 299 | struct chunk errmsg[HTTP_ERR_SIZE]; /* default or customized error messages for known errors */ |
Willy Tarreau | dcd4771 | 2007-11-04 23:35:08 +0100 | [diff] [blame] | 300 | int uuid; /* universally unique proxy ID, used for SNMP */ |
Willy Tarreau | c73ce2b | 2008-01-06 10:55:10 +0100 | [diff] [blame] | 301 | unsigned int backlog; /* force the frontend's listen backlog */ |
Willy Tarreau | 0b9c02c | 2009-02-04 22:05:05 +0100 | [diff] [blame] | 302 | unsigned int bind_proc; /* bitmask of processes using this proxy. 0 = all. */ |
Willy Tarreau | f073a83 | 2009-03-01 23:21:47 +0100 | [diff] [blame] | 303 | struct error_snapshot invalid_req, invalid_rep; /* captures of last errors */ |
Willy Tarreau | 84b57da | 2009-06-14 11:10:45 +0200 | [diff] [blame] | 304 | |
| 305 | /* used only during configuration parsing */ |
| 306 | int no_options; /* PR_O_REDISP, PR_O_TRANSP, ... */ |
| 307 | int no_options2; /* PR_O2_* */ |
Krzysztof Piotr Oledzki | 052d4fd | 2009-10-04 14:52:57 +0200 | [diff] [blame] | 308 | |
Willy Tarreau | 90a570f | 2009-10-04 20:54:54 +0200 | [diff] [blame] | 309 | struct { |
| 310 | const char *file; /* file where the section appears */ |
| 311 | int line; /* line where the section appears */ |
Willy Tarreau | 53fb4ae | 2009-10-04 23:04:08 +0200 | [diff] [blame] | 312 | struct eb32_node id; /* place in the tree of used IDs */ |
| 313 | struct eb_root used_listener_id;/* list of listener IDs in use */ |
| 314 | struct eb_root used_server_id; /* list of server IDs in use */ |
Willy Tarreau | 90a570f | 2009-10-04 20:54:54 +0200 | [diff] [blame] | 315 | } conf; /* config information */ |
Willy Tarreau | 258a14b | 2010-07-13 16:24:48 +0200 | [diff] [blame] | 316 | void *parent; /* parent of the proxy when applicable */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 317 | }; |
| 318 | |
Willy Tarreau | 55ea757 | 2007-06-17 19:56:27 +0200 | [diff] [blame] | 319 | struct switching_rule { |
| 320 | struct list list; /* list linked to from the proxy */ |
| 321 | struct acl_cond *cond; /* acl condition to meet */ |
| 322 | union { |
| 323 | struct proxy *backend; /* target backend */ |
| 324 | char *name; /* target backend name during config parsing */ |
| 325 | } be; |
| 326 | }; |
| 327 | |
Cyril Bonté | 47fdd8e | 2010-04-25 00:00:51 +0200 | [diff] [blame] | 328 | struct persist_rule { |
Willy Tarreau | 4de9149 | 2010-01-22 19:10:05 +0100 | [diff] [blame] | 329 | struct list list; /* list linked to from the proxy */ |
| 330 | struct acl_cond *cond; /* acl condition to meet */ |
Cyril Bonté | 47fdd8e | 2010-04-25 00:00:51 +0200 | [diff] [blame] | 331 | int type; |
Willy Tarreau | 4de9149 | 2010-01-22 19:10:05 +0100 | [diff] [blame] | 332 | }; |
| 333 | |
Emeric Brun | b982a3d | 2010-01-04 15:45:53 +0100 | [diff] [blame] | 334 | struct sticking_rule { |
| 335 | struct list list; /* list linked to from the proxy */ |
| 336 | struct acl_cond *cond; /* acl condition to meet */ |
| 337 | struct pattern_expr *expr; /* fetch expr to fetch key */ |
| 338 | int flags; /* STK_* */ |
| 339 | union { |
| 340 | struct stktable *t; /* target table */ |
| 341 | char *name; /* target table name during config parsing */ |
| 342 | } table; |
| 343 | }; |
| 344 | |
| 345 | |
Willy Tarreau | b463dfb | 2008-06-07 23:08:56 +0200 | [diff] [blame] | 346 | struct redirect_rule { |
| 347 | struct list list; /* list linked to from the proxy */ |
| 348 | struct acl_cond *cond; /* acl condition to meet */ |
| 349 | int type; |
| 350 | int rdr_len; |
| 351 | char *rdr_str; |
| 352 | int code; |
Willy Tarreau | 79da469 | 2008-11-19 20:03:04 +0100 | [diff] [blame] | 353 | unsigned int flags; |
Willy Tarreau | 0140f25 | 2008-11-19 21:07:09 +0100 | [diff] [blame] | 354 | int cookie_len; |
| 355 | char *cookie_str; |
Willy Tarreau | b463dfb | 2008-06-07 23:08:56 +0200 | [diff] [blame] | 356 | }; |
| 357 | |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 358 | extern struct proxy *proxy; |
Willy Tarreau | 53fb4ae | 2009-10-04 23:04:08 +0200 | [diff] [blame] | 359 | extern struct eb_root used_proxy_id; /* list of proxy IDs in use */ |
Willy Tarreau | baaee00 | 2006-06-26 02:48:02 +0200 | [diff] [blame] | 360 | |
| 361 | #endif /* _TYPES_PROXY_H */ |
| 362 | |
| 363 | /* |
| 364 | * Local variables: |
| 365 | * c-indent-level: 8 |
| 366 | * c-basic-offset: 8 |
| 367 | * End: |
| 368 | */ |