1 /*
2  * include/types/stream.h
3  * This file defines everything related to streams.
4  *
5  * Copyright (C) 2000-2015 Willy Tarreau - w@1wt.eu
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  */
21 
22 #ifndef _TYPES_STREAM_H
23 #define _TYPES_STREAM_H
24 
25 
26 #include <sys/time.h>
27 #include <unistd.h>
28 #include <netinet/in.h>
29 #include <arpa/inet.h>
30 
31 #include <common/config.h>
32 #include <common/mini-clist.h>
33 
34 #include <types/channel.h>
35 #include <types/filters.h>
36 #include <types/hlua.h>
37 #include <types/obj_type.h>
38 #include <types/http_ana.h>
39 #include <types/proxy.h>
40 #include <types/queue.h>
41 #include <types/server.h>
42 #include <types/session.h>
43 #include <types/stream_interface.h>
44 #include <types/task.h>
45 #include <types/stick_table.h>
46 #include <types/vars.h>
47 
48 /* Various Stream Flags, bits values 0x01 to 0x100 (shift 0) */
49 #define SF_DIRECT	0x00000001	/* connection made on the server matching the client cookie */
50 #define SF_ASSIGNED	0x00000002	/* no need to assign a server to this stream */
51 #define SF_ADDR_SET	0x00000004	/* this stream's server address has been set */
52 #define SF_BE_ASSIGNED	0x00000008	/* a backend was assigned. Conns are accounted. */
53 
54 #define SF_FORCE_PRST	0x00000010	/* force persistence here, even if server is down */
55 #define SF_MONITOR	0x00000020	/* this stream comes from a monitoring system */
56 #define SF_CURR_SESS	0x00000040	/* a connection is currently being counted on the server */
57 /* unused: 0x00000080 */
58 #define SF_REDISP	0x00000100	/* set if this stream was redispatched from one server to another */
59 #define SF_IGNORE	0x00000200      /* The stream lead to a mux upgrade, and should be ignored */
60 #define SF_REDIRECTABLE	0x00000400	/* set if this stream is redirectable (GET or HEAD) */
61 #define SF_HTX          0x00000800      /* set if this stream is an htx stream */
62 
63 /* stream termination conditions, bits values 0x1000 to 0x7000 (0-9 shift 12) */
64 #define SF_ERR_NONE     0x00000000	/* normal end of request */
65 #define SF_ERR_LOCAL    0x00001000	/* the proxy locally processed this request => not an error */
66 #define SF_ERR_CLITO    0x00002000	/* client time-out */
67 #define SF_ERR_CLICL    0x00003000	/* client closed (read/write error) */
68 #define SF_ERR_SRVTO    0x00004000	/* server time-out, connect time-out */
69 #define SF_ERR_SRVCL    0x00005000	/* server closed (connect/read/write error) */
70 #define SF_ERR_PRXCOND  0x00006000	/* the proxy decided to close (deny...) */
71 #define SF_ERR_RESOURCE 0x00007000	/* the proxy encountered a lack of a local resources (fd, mem, ...) */
72 #define SF_ERR_INTERNAL 0x00008000	/* the proxy encountered an internal error */
73 #define SF_ERR_DOWN     0x00009000	/* the proxy killed a stream because the backend became unavailable */
74 #define SF_ERR_KILLED   0x0000a000	/* the proxy killed a stream because it was asked to do so */
75 #define SF_ERR_UP       0x0000b000	/* the proxy killed a stream because a preferred backend became available */
76 #define SF_ERR_CHK_PORT 0x0000c000	/* no port could be found for a health check. TODO: check SF_ERR_SHIFT */
77 #define SF_ERR_MASK     0x0000f000	/* mask to get only stream error flags */
78 #define SF_ERR_SHIFT    12		/* bit shift */
79 
80 /* stream state at termination, bits values 0x10000 to 0x70000 (0-7 shift 16) */
81 #define SF_FINST_R	0x00010000	/* stream ended during client request */
82 #define SF_FINST_C	0x00020000	/* stream ended during server connect */
83 #define SF_FINST_H	0x00030000	/* stream ended during server headers */
84 #define SF_FINST_D	0x00040000	/* stream ended during data phase */
85 #define SF_FINST_L	0x00050000	/* stream ended while pushing last data to client */
86 #define SF_FINST_Q	0x00060000	/* stream ended while waiting in queue for a server slot */
87 #define SF_FINST_T	0x00070000	/* stream ended tarpitted */
88 #define SF_FINST_MASK	0x00070000	/* mask to get only final stream state flags */
89 #define	SF_FINST_SHIFT	16		/* bit shift */
90 
91 #define SF_IGNORE_PRST	0x00080000	/* ignore persistence */
92 
93 #define SF_SRV_REUSED   0x00100000	/* the server-side connection was reused */
94 
95 
96 /* flags for the proxy of the master CLI */
97 /* 0x1.. to 0x3 are reserved for ACCESS_LVL_MASK */
98 
99 #define PCLI_F_PROMPT          0x4
100 #define PCLI_F_PAYLOAD         0x8
101 
102 /* some external definitions */
103 struct strm_logs {
104 	int logwait;                    /* log fields waiting to be collected : LW_* */
105 	int level;                      /* log level to force + 1 if > 0, -1 = no log */
106 	struct timeval accept_date;     /* date of the stream's accept() in user date */
107 	struct timeval tv_accept;       /* date of the stream's accept() in internal date (monotonic) */
108 	long t_handshake;               /* hanshake duration, -1 if never occurs */
109 	long t_idle;                    /* idle duration, -1 if never occurs */
110 	struct timeval tv_request;      /* date the request arrives, {0,0} if never occurs */
111 	long  t_queue;                  /* delay before the stream gets out of the connect queue, -1 if never occurs */
112 	long  t_connect;                /* delay before the connect() to the server succeeds, -1 if never occurs */
113 	long  t_data;                   /* delay before the first data byte from the server ... */
114 	unsigned long t_close;          /* total stream duration */
115 	unsigned long srv_queue_pos;    /* number of streams de-queued while waiting for a connection slot on this server */
116 	unsigned long prx_queue_pos;    /* number of streams de-qeuued while waiting for a connection slot on this instance */
117 	long long bytes_in;             /* number of bytes transferred from the client to the server */
118 	long long bytes_out;            /* number of bytes transferred from the server to the client */
119 };
120 
121 struct stream {
122 	int flags;                      /* some flags describing the stream */
123 	unsigned int uniq_id;           /* unique ID used for the traces */
124 	enum obj_type *target;          /* target to use for this stream */
125 
126 	struct channel req;             /* request channel */
127 	struct channel res;             /* response channel */
128 
129 	struct proxy *be;               /* the proxy this stream depends on for the server side */
130 
131 	struct session *sess;           /* the session this stream is attached to */
132 
133 	struct server *srv_conn;        /* stream already has a slot on a server and is not in queue */
134 	struct pendconn *pend_pos;      /* if not NULL, points to the pending position in the pending queue */
135 
136 	struct http_txn *txn;           /* current HTTP transaction being processed. Should become a list. */
137 
138 	struct task *task;              /* the task associated with this stream */
139 	unsigned short pending_events;	/* the pending events not yet processed by the stream.
140 					 * This is a bit field of TASK_WOKEN_* */
141 	int16_t priority_class;         /* priority class of the stream for the pending queue */
142 	int32_t priority_offset;        /* priority offset of the stream for the pending queue */
143 
144 	struct list list;               /* position in global streams list */
145 	struct list by_srv;             /* position in server stream list */
146 	struct list back_refs;          /* list of users tracking this stream */
147 	struct buffer_wait buffer_wait; /* position in the list of objects waiting for a buffer */
148 
149 	struct freq_ctr call_rate;      /* stream task call rate */
150 
151 	short store_count;
152 	enum obj_type obj_type;         /* object type == OBJ_TYPE_STREAM */
153 	/* 1 unused bytes here */
154 
155 	struct {
156 		struct stksess *ts;
157 		struct stktable *table;
158 	} store[8];                     /* tracked stickiness values to store */
159 
160 	struct sockaddr_storage *target_addr;   /* the address to join if not null */
161 	struct stkctr stkctr[MAX_SESS_STKCTR];  /* content-aware stick counters */
162 
163 	struct strm_flt strm_flt;               /* current state of filters active on this stream */
164 
165 	char **req_cap;                         /* array of captures from the request (may be NULL) */
166 	char **res_cap;                         /* array of captures from the response (may be NULL) */
167 	struct vars vars_txn;                   /* list of variables for the txn scope. */
168 	struct vars vars_reqres;                /* list of variables for the request and resp scope. */
169 
170 	struct stream_interface si[2];          /* client and server stream interfaces */
171 	struct strm_logs logs;                  /* logs for this stream */
172 
173 	void (*do_log)(struct stream *s);       /* the function to call in order to log (or NULL) */
174 	void (*srv_error)(struct stream *s,     /* the function to call upon unrecoverable server errors (or NULL) */
175 			  struct stream_interface *si);
176 
177 	int pcli_next_pid;                      /* next target PID to use for the CLI proxy */
178 	int pcli_flags;                         /* flags for CLI proxy */
179 
180 	char *unique_id;                        /* custom unique ID */
181 
182 	/* These two pointers are used to resume the execution of the rule lists. */
183 	struct list *current_rule_list;         /* this is used to store the current executed rule list. */
184 	void *current_rule;                     /* this is used to store the current rule to be resumed. */
185 	struct hlua *hlua;                      /* lua runtime context */
186 
187 	/* Context */
188 	struct {
189 		struct dns_requester *dns_requester; /* owner of the resolution */
190 		char *hostname_dn;              /* hostname being resolve, in domain name format */
191 		int hostname_dn_len;            /* size of hostname_dn */
192 		/* 4 unused bytes here */
193 		struct act_rule *parent;        /* rule which requested this resolution */
194 	} dns_ctx;                              /* context information for DNS resolution */
195 };
196 
197 #endif /* _TYPES_STREAM_H */
198 
199 /*
200  * Local variables:
201  *  c-indent-level: 8
202  *  c-basic-offset: 8
203  * End:
204  */
205