]>
Commit | Line | Data |
---|---|---|
07541774 ER |
1 | --- lighttpd-1.4.19/src/mod_evasive.c 2008-09-19 17:50:24.307245276 +0300 |
2 | +++ lighttpd-1.4.22/src/mod_evasive.c 2009-05-12 02:21:58.524447939 +0300 | |
3 | @@ -28,11 +28,15 @@ | |
53e13862 SP |
4 | typedef struct { |
5 | unsigned short max_conns; | |
07541774 | 6 | unsigned short silent; |
53e13862 SP |
7 | + unsigned short http_status_code; |
8 | + unsigned int retry_after; | |
9 | } plugin_config; | |
10 | ||
11 | typedef struct { | |
12 | PLUGIN_DATA; | |
0315e022 | 13 | |
53e13862 | 14 | + buffer *evasive_rftmp; |
0315e022 | 15 | + |
53e13862 | 16 | plugin_config **config_storage; |
0315e022 ER |
17 | |
18 | plugin_config conf; | |
07541774 | 19 | @@ -46,6 +50,10 @@ |
0315e022 | 20 | |
53e13862 | 21 | p = calloc(1, sizeof(*p)); |
0315e022 | 22 | |
53e13862 SP |
23 | + p->evasive_rftmp = buffer_init(); |
24 | + | |
25 | + buffer_prepare_copy(p->evasive_rftmp, 255); | |
0315e022 | 26 | + |
53e13862 SP |
27 | return p; |
28 | } | |
29 | ||
07541774 | 30 | @@ -56,6 +64,8 @@ |
53e13862 SP |
31 | |
32 | if (!p) return HANDLER_GO_ON; | |
0315e022 | 33 | |
53e13862 | 34 | + buffer_free(p->evasive_rftmp); |
0315e022 | 35 | + |
53e13862 SP |
36 | if (p->config_storage) { |
37 | size_t i; | |
38 | for (i = 0; i < srv->config_context->used; i++) { | |
6da3f2a1 | 39 | @@ -85,6 +85,8 @@ |
07541774 | 40 | config_values_t cv[] = { |
6da3f2a1 ER |
41 | { "evasive.max-conns-per-ip", NULL, T_CONFIG_SHORT, T_CONFIG_SCOPE_CONNECTION }, /* 0 */ |
42 | { "evasive.silent", NULL, T_CONFIG_BOOLEAN, T_CONFIG_SCOPE_CONNECTION }, /* 1 */ | |
07541774 ER |
43 | + { "evasive.http-status-code", NULL, T_CONFIG_SHORT, T_CONFIG_SCOPE_CONNECTION }, /* 2 */ |
44 | + { "evasive.retry-after", NULL, T_CONFIG_SHORT, T_CONFIG_SCOPE_CONNECTION }, /* 3 */ | |
53e13862 SP |
45 | { NULL, NULL, T_CONFIG_UNSET, T_CONFIG_SCOPE_UNSET } |
46 | }; | |
07541774 | 47 | |
6da3f2a1 | 48 | @@ -94,11 +96,15 @@ |
53e13862 | 49 | plugin_config *s; |
0315e022 | 50 | |
53e13862 SP |
51 | s = calloc(1, sizeof(plugin_config)); |
52 | - s->max_conns = 0; | |
07541774 | 53 | - s->silent = 0; |
53e13862 | 54 | + s->max_conns = 0; |
07541774 | 55 | + s->silent = 0; |
53e13862 SP |
56 | + s->http_status_code = 503; |
57 | + s->retry_after = 0; | |
0315e022 | 58 | |
53e13862 | 59 | cv[0].destination = &(s->max_conns); |
6da3f2a1 | 60 | cv[1].destination = &(s->silent); |
07541774 ER |
61 | + cv[2].destination = &(s->http_status_code); |
62 | + cv[3].destination = &(s->retry_after); | |
0315e022 | 63 | |
53e13862 | 64 | p->config_storage[i] = s; |
0315e022 | 65 | |
07541774 | 66 | @@ -107,6 +123,8 @@ |
53e13862 SP |
67 | |
68 | PATCH(max_conns); | |
07541774 | 69 | PATCH(silent); |
53e13862 SP |
70 | + PATCH(http_status_code); |
71 | + PATCH(retry_after); | |
0315e022 | 72 | |
53e13862 SP |
73 | /* skip the first, the global context */ |
74 | for (i = 1; i < srv->config_context->used; i++) { | |
07541774 | 75 | @@ -124,6 +142,10 @@ |
53e13862 | 76 | PATCH(max_conns); |
07541774 ER |
77 | } else if (buffer_is_equal_string(du->key, CONST_STR_LEN("evasive.silent"))) { |
78 | PATCH(silent); | |
53e13862 SP |
79 | + } else if (buffer_is_equal_string(du->key, CONST_STR_LEN("evasive.http-status-code"))) { |
80 | + PATCH(http_status_code); | |
81 | + } else if (buffer_is_equal_string(du->key, CONST_STR_LEN("evasive.retry-after"))) { | |
82 | + PATCH(retry_after); | |
83 | } | |
84 | } | |
85 | } | |
07541774 | 86 | @@ -192,8 +214,10 @@ |
4fa4837c ER |
87 | inet_ntop_cache_get_ip(srv, &(con->dst_addr)), |
88 | "turned away. Too many connections."); | |
89 | ||
90 | - con->http_status = 403; | |
91 | con->mode = DIRECT; | |
92 | + con->http_status = p->conf.http_status_code; | |
93 | + buffer_copy_long(p->evasive_rftmp, p->conf.retry_after); | |
94 | + response_header_overwrite(srv, con, CONST_STR_LEN("Retry-After"), CONST_BUF_LEN(p->evasive_rftmp)); | |
95 | return HANDLER_FINISHED; | |
53e13862 | 96 | } |
4fa4837c | 97 | } |