varnish-cache/bin/varnishd/http1/cache_http1_proto.c
0
/*-
1
 * Copyright (c) 2006 Verdens Gang AS
2
 * Copyright (c) 2006-2015 Varnish Software AS
3
 * All rights reserved.
4
 *
5
 * Author: Poul-Henning Kamp <phk@phk.freebsd.dk>
6
 *
7
 * SPDX-License-Identifier: BSD-2-Clause
8
 *
9
 * Redistribution and use in source and binary forms, with or without
10
 * modification, are permitted provided that the following conditions
11
 * are met:
12
 * 1. Redistributions of source code must retain the above copyright
13
 *    notice, this list of conditions and the following disclaimer.
14
 * 2. Redistributions in binary form must reproduce the above copyright
15
 *    notice, this list of conditions and the following disclaimer in the
16
 *    documentation and/or other materials provided with the distribution.
17
 *
18
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
19
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21
 * ARE DISCLAIMED.  IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
22
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28
 * SUCH DAMAGE.
29
 *
30
 * HTTP protocol requests
31
 *
32
 * The trouble with the "until magic sequence" design of HTTP protocol messages
33
 * is that either you have to read a single character at a time, which is
34
 * inefficient, or you risk reading too much, and pre-read some of the object,
35
 * or even the next pipelined request, which follows the one you want.
36
 *
37
 * HTC reads a HTTP protocol header into a workspace, subject to limits,
38
 * and stops when we see the magic marker (double [CR]NL), and if we overshoot,
39
 * it keeps track of the "pipelined" data.
40
 *
41
 * We use this both for client and backend connections.
42
 */
43
44
#include "config.h"
45
46
#include "cache/cache_varnishd.h"
47
#include "cache/cache_transport.h"
48
49
#include "cache_http1.h"
50
51
#include "vct.h"
52
53
const int HTTP1_Req[3] = {
54
        HTTP_HDR_METHOD, HTTP_HDR_URL, HTTP_HDR_PROTO
55
};
56
57
const int HTTP1_Resp[3] = {
58
        HTTP_HDR_PROTO, HTTP_HDR_STATUS, HTTP_HDR_REASON
59
};
60
61
/*--------------------------------------------------------------------
62
 * Check if we have a complete HTTP request or response yet
63
 */
64
65
enum htc_status_e v_matchproto_(htc_complete_f)
66 513786
HTTP1_Complete(struct http_conn *htc)
67
{
68
        char *p;
69
        enum htc_status_e retval;
70
71 513786
        CHECK_OBJ_NOTNULL(htc, HTTP_CONN_MAGIC);
72 513786
        AN(WS_Reservation(htc->ws));
73 513786
        assert(pdiff(htc->rxbuf_b, htc->rxbuf_e) <= WS_ReservationSize(htc->ws));
74
75
        /* Skip any leading white space */
76 515266
        for (p = htc->rxbuf_b ; p < htc->rxbuf_e && vct_islws(*p); p++)
77 1480
                continue;
78 513786
        if (p == htc->rxbuf_e)
79 278933
                return (HTC_S_EMPTY);
80
81
        /* Do not return a partial H2 connection preface */
82 234853
        retval = H2_prism_complete(htc);
83 234853
        if (retval != HTC_S_JUNK)
84 11837
                return (retval);
85
86
        /*
87
         * Here we just look for NL[CR]NL to see that reception
88
         * is completed.  More stringent validation happens later.
89
         */
90 804013
        while (1) {
91 804013
                p = memchr(p, '\n', htc->rxbuf_e - p);
92 804013
                if (p == NULL)
93 12878
                        return (HTC_S_MORE);
94 791135
                if (++p == htc->rxbuf_e)
95 890
                        return (HTC_S_MORE);
96 790245
                if (*p == '\r' && ++p == htc->rxbuf_e)
97 120
                        return (HTC_S_MORE);
98 790125
                if (*p == '\n')
99 209128
                        break;
100
        }
101 209128
        return (HTC_S_COMPLETE);
102 513786
}
103
104
/*--------------------------------------------------------------------
105
 * Dissect the headers of the HTTP protocol message.
106
 */
107
108
static uint16_t
109 209135
http1_dissect_hdrs(struct http *hp, char *p, struct http_conn *htc,
110
    unsigned maxhdr)
111
{
112
        char *q, *r, *s;
113
        int i;
114
115 209135
        assert(p > htc->rxbuf_b);
116 209135
        assert(p <= htc->rxbuf_e);
117 209135
        hp->nhd = HTTP_HDR_FIRST;
118 209135
        r = NULL;               /* For FlexeLint */
119 780255
        for (; p < htc->rxbuf_e; p = r) {
120
121
                /* Find end of next header */
122 780250
                q = r = p;
123 780250
                if (vct_iscrlf(p, htc->rxbuf_e))
124 208210
                        break;
125 12120043
                while (r < htc->rxbuf_e) {
126 12120008
                        if (vct_ishdrval(*r)) {
127 11547847
                                r++;
128 11547847
                                continue;
129
                        }
130 572161
                        i = vct_iscrlf(r, htc->rxbuf_e);
131 572161
                        if (i == 0) {
132 320
                                VSLb(hp->vsl, SLT_BogoHeader,
133 160
                                    "Header has ctrl char 0x%02x", *r);
134 160
                                return (400);
135
                        }
136 572001
                        q = r;
137 572001
                        r += i;
138 572001
                        assert(r <= htc->rxbuf_e);
139 572001
                        if (r == htc->rxbuf_e)
140 0
                                break;
141 572001
                        if (vct_iscrlf(r, htc->rxbuf_e))
142 207883
                                break;
143
                        /* If line does not continue: got it. */
144 364118
                        if (!vct_issp(*r))
145 363758
                                break;
146
147
                        /* Clear line continuation LWS to spaces */
148 720
                        while (q < r)
149 360
                                *q++ = ' ';
150 760
                        while (q < htc->rxbuf_e && vct_issp(*q))
151 400
                                *q++ = ' ';
152
                }
153
154
                /* Empty header = end of headers */
155 571676
                if (p == q)
156 0
                        break;
157
158 571648
                if (q - p > maxhdr) {
159 320
                        VSLb(hp->vsl, SLT_BogoHeader, "Header too long: %.*s",
160 160
                            (int)(q - p > 20 ? 20 : q - p), p);
161 160
                        return (400);
162
                }
163
164 571488
                if (vct_islws(*p)) {
165 160
                        VSLb(hp->vsl, SLT_BogoHeader,
166
                            "1st header has white space: %.*s",
167 80
                            (int)(q - p > 20 ? 20 : q - p), p);
168 80
                        return (400);
169
                }
170
171 571408
                if (*p == ':') {
172 80
                        VSLb(hp->vsl, SLT_BogoHeader,
173
                            "Missing header name: %.*s",
174 40
                            (int)(q - p > 20 ? 20 : q - p), p);
175 40
                        return (400);
176
                }
177
178 572088
                while (q > p && vct_issp(q[-1]))
179 720
                        q--;
180 571360
                *q = '\0';
181
182 4961472
                for (s = p; *s != ':' && s < q; s++) {
183 4390312
                        if (!vct_istchar(*s)) {
184 400
                                VSLb(hp->vsl, SLT_BogoHeader,
185 200
                                    "Illegal char 0x%02x in header name", *s);
186 200
                                return (400);
187
                        }
188 4390112
                }
189 571160
                if (*s != ':') {
190 80
                        VSLb(hp->vsl, SLT_BogoHeader, "Header without ':' %.*s",
191 40
                            (int)(q - p > 20 ? 20 : q - p), p);
192 40
                        return (400);
193
                }
194
195 571120
                if (hp->nhd < hp->shd) {
196 571120
                        hp->hdf[hp->nhd] = 0;
197 571120
                        hp->hd[hp->nhd].b = p;
198 571120
                        hp->hd[hp->nhd].e = q;
199 571120
                        hp->nhd++;
200 571120
                } else {
201 0
                        VSLb(hp->vsl, SLT_BogoHeader, "Too many headers: %.*s",
202 0
                            (int)(q - p > 20 ? 20 : q - p), p);
203 0
                        return (400);
204
                }
205 571120
        }
206 208215
        i = vct_iscrlf(p, htc->rxbuf_e);
207 208215
        assert(i > 0);          /* HTTP1_Complete guarantees this */
208 208205
        p += i;
209 208205
        HTC_RxPipeline(htc, p);
210 208205
        htc->rxbuf_e = p;
211 208205
        return (0);
212 208885
}
213
214
/*--------------------------------------------------------------------
215
 * Deal with first line of HTTP protocol message.
216
 */
217
218
static uint16_t
219 209123
http1_splitline(struct http *hp, struct http_conn *htc, const int *hf,
220
    unsigned maxhdr)
221
{
222
        char *p, *q;
223
        int i;
224
225 209123
        assert(hf == HTTP1_Req || hf == HTTP1_Resp);
226 209123
        CHECK_OBJ_NOTNULL(htc, HTTP_CONN_MAGIC);
227 209123
        CHECK_OBJ_NOTNULL(hp, HTTP_MAGIC);
228 209123
        assert(htc->rxbuf_e >= htc->rxbuf_b);
229
230 209123
        AZ(hp->hd[hf[0]].b);
231 209123
        AZ(hp->hd[hf[1]].b);
232 209123
        AZ(hp->hd[hf[2]].b);
233
234
        /* Skip leading LWS */
235 209323
        for (p = htc->rxbuf_b ; vct_islws(*p); p++)
236 200
                continue;
237 209123
        hp->hd[hf[0]].b = p;
238
239
        /* First field cannot contain SP or CTL */
240 1252429
        for (; !vct_issp(*p); p++) {
241 1043466
                if (vct_isctl(*p))
242 160
                        return (400);
243 1043306
        }
244 208963
        hp->hd[hf[0]].e = p;
245 208963
        assert(Tlen(hp->hd[hf[0]]));
246 208963
        *p++ = '\0';
247
248
        /* Skip SP */
249 209203
        for (; vct_issp(*p); p++) {
250 240
                if (vct_isctl(*p))
251 0
                        return (400);
252 240
        }
253 208963
        hp->hd[hf[1]].b = p;
254
255
        /* Second field cannot contain LWS or CTL */
256 1506191
        for (; !vct_islws(*p); p++) {
257 1297228
                if (vct_isctl(*p))
258 0
                        return (400);
259 1297228
        }
260 208963
        hp->hd[hf[1]].e = p;
261 208963
        if (!Tlen(hp->hd[hf[1]]))
262 40
                return (400);
263
264
        /* Skip SP */
265 208923
        q = p;
266 417574
        for (; vct_issp(*p); p++) {
267 208651
                if (vct_isctl(*p))
268 0
                        return (400);
269 208651
        }
270 208923
        if (q < p)
271 208609
                *q = '\0';      /* Nul guard for the 2nd field. If q == p
272
                                 * (the third optional field is not
273
                                 * present), the last nul guard will
274
                                 * cover this field. */
275
276
        /* Third field is optional and cannot contain CTL except TAB */
277 208923
        q = p;
278 1393089
        for (; p < htc->rxbuf_e && !vct_iscrlf(p, htc->rxbuf_e); p++) {
279 1184206
                if (vct_isctl(*p) && !vct_issp(*p))
280 40
                        return (400);
281 1184166
        }
282 208865
        if (p > q) {
283 208425
                hp->hd[hf[2]].b = q;
284 208425
                hp->hd[hf[2]].e = p;
285 208425
        }
286
287
        /* Skip CRLF */
288 208865
        i = vct_iscrlf(p, htc->rxbuf_e);
289 208865
        if (!i)
290 0
                return (400);
291 208865
        *p = '\0';
292 208865
        p += i;
293
294 208865
        http_Proto(hp);
295
296 208865
        return (http1_dissect_hdrs(hp, p, htc, maxhdr));
297 209105
}
298
299
/*--------------------------------------------------------------------*/
300
301
static body_status_t
302 208040
http1_body_status(const struct http *hp, struct http_conn *htc, int request)
303
{
304
        ssize_t cl;
305
        const char *b;
306
307 208040
        CHECK_OBJ_NOTNULL(htc, HTTP_CONN_MAGIC);
308 208040
        CHECK_OBJ_NOTNULL(hp, HTTP_MAGIC);
309
310 208040
        htc->content_length = -1;
311
312 208040
        cl = http_GetContentLength(hp);
313 208040
        if (cl == -2)
314 160
                return (BS_ERROR);
315 207880
        if (http_GetHdr(hp, H_Transfer_Encoding, &b)) {
316 6280
                if (!http_coding_eq(b, chunked))
317 80
                        return (BS_ERROR);
318 6200
                if (cl != -1) {
319
                        /*
320
                         * RFC7230 3.3.3 allows more lenient handling
321
                         * but we're going to be strict.
322
                         */
323 80
                        return (BS_ERROR);
324
                }
325 6120
                return (BS_CHUNKED);
326
        }
327 201600
        if (cl >= 0) {
328 76796
                htc->content_length = cl;
329 76796
                return (cl == 0 ? BS_NONE : BS_LENGTH);
330
        }
331
332 124804
        if (hp->protover == 11 && request)
333 122524
                return (BS_NONE);
334
335 2280
        if (http_HdrIs(hp, H_Connection, "keep-alive")) {
336
                /*
337
                 * Keep alive with neither TE=Chunked or C-Len is impossible.
338
                 * We assume a zero length body.
339
                 */
340 80
                return (BS_NONE);
341
        }
342
343
        /*
344
         * Fall back to EOF transfer.
345
         */
346 2200
        return (BS_EOF);
347 208040
}
348
349
/*--------------------------------------------------------------------*/
350
351
uint16_t
352 128011
HTTP1_DissectRequest(struct http_conn *htc, struct http *hp)
353
{
354
        uint16_t retval;
355
        const char *p;
356 128011
        const char *b = NULL, *e;
357
358 128011
        CHECK_OBJ_NOTNULL(htc, HTTP_CONN_MAGIC);
359 128011
        CHECK_OBJ_NOTNULL(hp, HTTP_MAGIC);
360
361 256022
        retval = http1_splitline(hp, htc,
362 128011
            HTTP1_Req, cache_param->http_req_hdr_len);
363 128011
        if (retval != 0)
364 600
                return (retval);
365
366 127411
        if (hp->protover < 10 || hp->protover > 11)
367 480
                return (400);
368
369
        /* RFC2616, section 5.2, point 1 */
370 126933
        if (http_scheme_at(hp->hd[HTTP_HDR_URL].b, http))
371 120
                b = hp->hd[HTTP_HDR_URL].b + 7;
372 126813
        else if (FEATURE(FEATURE_HTTPS_SCHEME) &&
373 40
            http_scheme_at(hp->hd[HTTP_HDR_URL].b, https))
374 40
                b = hp->hd[HTTP_HDR_URL].b + 8;
375 126933
        if (b) {
376 160
                e = strchr(b, '/');
377 160
                if (e) {
378 160
                        http_Unset(hp, H_Host);
379 160
                        http_PrintfHeader(hp, "Host: %.*s", (int)(e - b), b);
380 160
                        hp->hd[HTTP_HDR_URL].b = e;
381 160
                }
382 160
        }
383
384 126933
        htc->body_status = http1_body_status(hp, htc, 1);
385 126933
        if (htc->body_status == BS_ERROR)
386 160
                return (400);
387
388 126773
        p = http_GetMethod(hp);
389 126773
        AN(p);
390
391 126773
        if (htc->body_status == BS_EOF) {
392 560
                assert(hp->protover == 10);
393
                /* RFC1945 8.3 p32 and D.1.1 p58 */
394 560
                if (http_method_eq(p, POST) || http_method_eq(p, PUT))
395 80
                        return (400);
396 480
                htc->body_status = BS_NONE;
397 480
        }
398
399
        /* HEAD with a body is a hard error */
400 126693
        if (htc->body_status != BS_NONE && http_method_eq(p, HEAD))
401 0
                return (400);
402
403 126693
        return (retval);
404 128013
}
405
406
/*--------------------------------------------------------------------*/
407
408
uint16_t
409 81120
HTTP1_DissectResponse(struct http_conn *htc, struct http *hp,
410
    const struct http *rhttp)
411
{
412 81120
        uint16_t retval = 0;
413
        const char *p;
414
415 81120
        CHECK_OBJ_NOTNULL(htc, HTTP_CONN_MAGIC);
416 81120
        CHECK_OBJ_NOTNULL(hp, HTTP_MAGIC);
417 81120
        CHECK_OBJ_NOTNULL(rhttp, HTTP_MAGIC);
418
419 162240
        if (http1_splitline(hp, htc,
420 81120
            HTTP1_Resp, cache_param->http_resp_hdr_len))
421 320
                retval = 503;
422
423 81120
        if (retval == 0 && hp->protover < 10)
424 0
                retval = 503;
425
426 81120
        if (retval == 0 && hp->protover > rhttp->protover)
427 40
                http_SetH(hp, HTTP_HDR_PROTO, rhttp->hd[HTTP_HDR_PROTO].b);
428
429 81120
        if (retval == 0 && Tlen(hp->hd[HTTP_HDR_STATUS]) != 3)
430 120
                retval = 503;
431
432 81120
        if (retval == 0) {
433 80677
                p = hp->hd[HTTP_HDR_STATUS].b;
434
435 161114
                if (p[0] >= '1' && p[0] <= '9' &&
436 80557
                    p[1] >= '0' && p[1] <= '9' &&
437 80477
                    p[2] >= '0' && p[2] <= '9')
438 80397
                        hp->status =
439 80397
                            100 * (p[0] - '0') + 10 * (p[1] - '0') + p[2] - '0';
440
                else
441 280
                        retval = 503;
442 80677
        }
443
444 81120
        if (retval != 0) {
445 1440
                VSLb(hp->vsl, SLT_HttpGarbage, "%.*s",
446 720
                    (int)(htc->rxbuf_e - htc->rxbuf_b), htc->rxbuf_b);
447 720
                assert(retval >= 100 && retval <= 999);
448 720
                assert(retval == 503);
449 720
                http_SetStatus(hp, 503, NULL);
450 720
        }
451
452 81120
        if (hp->hd[HTTP_HDR_REASON].b == NULL ||
453 81037
            !Tlen(hp->hd[HTTP_HDR_REASON])) {
454 172
                http_SetH(hp, HTTP_HDR_REASON,
455 86
                    http_Status2Reason(hp->status, NULL));
456 86
        }
457
458 81114
        htc->body_status = http1_body_status(hp, htc, 0);
459
460 81114
        return (retval);
461
}
462
463
/*--------------------------------------------------------------------*/
464
465
static unsigned
466 2136751
http1_WrTxt(struct v1l *v1l, const txt *hh, const char *suf)
467
{
468
        unsigned u;
469
470 2136751
        AN(hh);
471 2136751
        AN(hh->b);
472 2136751
        AN(hh->e);
473 2136751
        u = V1L_Write(v1l, hh->b, hh->e - hh->b);
474 2136751
        if (suf != NULL)
475 2136374
                u += V1L_Write(v1l, suf, -1);
476 2136753
        return (u);
477
}
478
479
unsigned
480 202126
HTTP1_Write(struct v1l *v1l, const struct http *hp, const int *hf)
481
{
482
        unsigned u, l;
483
484 202126
        assert(hf == HTTP1_Req || hf == HTTP1_Resp);
485 202126
        AN(hp->hd[hf[0]].b);
486 202126
        AN(hp->hd[hf[1]].b);
487 202126
        AN(hp->hd[hf[2]].b);
488 202126
        l = http1_WrTxt(v1l, &hp->hd[hf[0]], " ");
489 202126
        l += http1_WrTxt(v1l, &hp->hd[hf[1]], " ");
490 202126
        l += http1_WrTxt(v1l, &hp->hd[hf[2]], "\r\n");
491
492 1732831
        for (u = HTTP_HDR_FIRST; u < hp->nhd; u++)
493 1530705
                l += http1_WrTxt(v1l, &hp->hd[u], "\r\n");
494 202126
        l += V1L_Write(v1l, "\r\n", -1);
495 202126
        return (l);
496
}