4e27686c63
Closes #709 Signed-off-by: Gustavo Zacarias <gustavo@zacarias.com.ar> Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
234 lines
5.2 KiB
Diff
234 lines
5.2 KiB
Diff
diff -Nura lighttpd-1.4.24/src/mod_rewrite.c lighttpd-1.4.24-changeset-r2683/src/mod_rewrite.c
|
|
--- lighttpd-1.4.24/src/mod_rewrite.c 2009-10-12 18:48:47.000000000 -0300
|
|
+++ lighttpd-1.4.24-changeset-r2683/src/mod_rewrite.c 2009-11-10 13:56:22.000000000 -0300
|
|
@@ -9,10 +9,9 @@
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
-typedef struct {
|
|
#ifdef HAVE_PCRE_H
|
|
+typedef struct {
|
|
pcre *key;
|
|
-#endif
|
|
|
|
buffer *value;
|
|
|
|
@@ -70,7 +69,6 @@
|
|
}
|
|
|
|
static int rewrite_rule_buffer_append(rewrite_rule_buffer *kvb, buffer *key, buffer *value, int once) {
|
|
-#ifdef HAVE_PCRE_H
|
|
size_t i;
|
|
const char *errptr;
|
|
int erroff;
|
|
@@ -109,18 +107,9 @@
|
|
kvb->used++;
|
|
|
|
return 0;
|
|
-#else
|
|
- UNUSED(kvb);
|
|
- UNUSED(value);
|
|
- UNUSED(once);
|
|
- UNUSED(key);
|
|
-
|
|
- return -1;
|
|
-#endif
|
|
}
|
|
|
|
static void rewrite_rule_buffer_free(rewrite_rule_buffer *kvb) {
|
|
-#ifdef HAVE_PCRE_H
|
|
size_t i;
|
|
|
|
for (i = 0; i < kvb->size; i++) {
|
|
@@ -130,7 +119,6 @@
|
|
}
|
|
|
|
if (kvb->ptr) free(kvb->ptr);
|
|
-#endif
|
|
|
|
free(kvb);
|
|
}
|
|
@@ -201,24 +189,29 @@
|
|
((data_string *)(da->value->data[j]))->key,
|
|
((data_string *)(da->value->data[j]))->value,
|
|
once)) {
|
|
-#ifdef HAVE_PCRE_H
|
|
log_error_write(srv, __FILE__, __LINE__, "sb",
|
|
"pcre-compile failed for", da->value->data[j]->key);
|
|
-#else
|
|
- log_error_write(srv, __FILE__, __LINE__, "s",
|
|
- "pcre support is missing, please install libpcre and the headers");
|
|
-#endif
|
|
}
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
+#else
|
|
+static int parse_config_entry(server *srv, array *ca, const char *option) {
|
|
+ static int logged_message = 0;
|
|
+ if (logged_message) return 0;
|
|
+ if (NULL != array_get_element(ca, option)) {
|
|
+ logged_message = 1;
|
|
+ log_error_write(srv, __FILE__, __LINE__, "s",
|
|
+ "pcre support is missing, please install libpcre and the headers");
|
|
+ }
|
|
+ return 0;
|
|
+}
|
|
+#endif
|
|
|
|
SETDEFAULTS_FUNC(mod_rewrite_set_defaults) {
|
|
- plugin_data *p = p_d;
|
|
size_t i = 0;
|
|
-
|
|
config_values_t cv[] = {
|
|
{ "url.rewrite-repeat", NULL, T_CONFIG_LOCAL, T_CONFIG_SCOPE_CONNECTION }, /* 0 */
|
|
{ "url.rewrite-once", NULL, T_CONFIG_LOCAL, T_CONFIG_SCOPE_CONNECTION }, /* 1 */
|
|
@@ -243,33 +236,37 @@
|
|
{ NULL, NULL, T_CONFIG_UNSET, T_CONFIG_SCOPE_UNSET }
|
|
};
|
|
|
|
+#ifdef HAVE_PCRE_H
|
|
+ plugin_data *p = p_d;
|
|
+
|
|
if (!p) return HANDLER_ERROR;
|
|
|
|
/* 0 */
|
|
p->config_storage = calloc(1, srv->config_context->used * sizeof(specific_config *));
|
|
+#else
|
|
+ UNUSED(p_d);
|
|
+#endif
|
|
|
|
for (i = 0; i < srv->config_context->used; i++) {
|
|
- plugin_config *s;
|
|
array *ca;
|
|
+#ifdef HAVE_PCRE_H
|
|
+ plugin_config *s;
|
|
|
|
s = calloc(1, sizeof(plugin_config));
|
|
s->rewrite = rewrite_rule_buffer_init();
|
|
s->rewrite_NF = rewrite_rule_buffer_init();
|
|
-
|
|
- cv[0].destination = s->rewrite;
|
|
- cv[1].destination = s->rewrite;
|
|
- cv[2].destination = s->rewrite_NF;
|
|
- cv[3].destination = s->rewrite_NF;
|
|
- cv[4].destination = s->rewrite;
|
|
- cv[5].destination = s->rewrite;
|
|
-
|
|
p->config_storage[i] = s;
|
|
+#endif
|
|
+
|
|
ca = ((data_config *)srv->config_context->data[i])->value;
|
|
|
|
if (0 != config_insert_values_global(srv, ca, cv)) {
|
|
return HANDLER_ERROR;
|
|
}
|
|
|
|
+#ifndef HAVE_PCRE_H
|
|
+# define parse_config_entry(srv, ca, x, option, y) parse_config_entry(srv, ca, option)
|
|
+#endif
|
|
parse_config_entry(srv, ca, s->rewrite, "url.rewrite-once", 1);
|
|
parse_config_entry(srv, ca, s->rewrite, "url.rewrite-final", 1);
|
|
parse_config_entry(srv, ca, s->rewrite_NF, "url.rewrite-if-not-file", 1);
|
|
@@ -280,7 +277,9 @@
|
|
|
|
return HANDLER_GO_ON;
|
|
}
|
|
+
|
|
#ifdef HAVE_PCRE_H
|
|
+
|
|
#define PATCH(x) \
|
|
p->conf.x = s->x;
|
|
static int mod_rewrite_patch_connection(server *srv, connection *con, plugin_data *p) {
|
|
@@ -330,7 +329,7 @@
|
|
|
|
return 0;
|
|
}
|
|
-#endif
|
|
+
|
|
URIHANDLER_FUNC(mod_rewrite_con_reset) {
|
|
plugin_data *p = p_d;
|
|
|
|
@@ -345,7 +344,6 @@
|
|
}
|
|
|
|
static int process_rewrite_rules(server *srv, connection *con, plugin_data *p, rewrite_rule_buffer *kvb) {
|
|
-#ifdef HAVE_PCRE_H
|
|
size_t i;
|
|
handler_ctx *hctx;
|
|
|
|
@@ -444,19 +442,11 @@
|
|
}
|
|
#undef N
|
|
}
|
|
-#else
|
|
- UNUSED(srv);
|
|
- UNUSED(con);
|
|
- UNUSED(p);
|
|
- UNUSED(hctx);
|
|
- UNUSED(kvb);
|
|
-#endif
|
|
|
|
return HANDLER_GO_ON;
|
|
}
|
|
|
|
URIHANDLER_FUNC(mod_rewrite_physical) {
|
|
-#ifdef HAVE_PCRE_H
|
|
plugin_data *p = p_d;
|
|
handler_t r;
|
|
stat_cache_entry *sce;
|
|
@@ -480,17 +470,11 @@
|
|
default:
|
|
return r;
|
|
}
|
|
-#else
|
|
- UNUSED(srv);
|
|
- UNUSED(con);
|
|
- UNUSED(p_d);
|
|
-#endif
|
|
|
|
return HANDLER_GO_ON;
|
|
}
|
|
|
|
URIHANDLER_FUNC(mod_rewrite_uri_handler) {
|
|
-#ifdef HAVE_PCRE_H
|
|
plugin_data *p = p_d;
|
|
|
|
mod_rewrite_patch_connection(srv, con, p);
|
|
@@ -498,29 +482,27 @@
|
|
if (!p->conf.rewrite) return HANDLER_GO_ON;
|
|
|
|
return process_rewrite_rules(srv, con, p, p->conf.rewrite);
|
|
-#else
|
|
- UNUSED(srv);
|
|
- UNUSED(con);
|
|
- UNUSED(p_d);
|
|
-#endif
|
|
|
|
return HANDLER_GO_ON;
|
|
}
|
|
+#endif
|
|
|
|
int mod_rewrite_plugin_init(plugin *p);
|
|
int mod_rewrite_plugin_init(plugin *p) {
|
|
p->version = LIGHTTPD_VERSION_ID;
|
|
p->name = buffer_init_string("rewrite");
|
|
|
|
+#ifdef HAVE_PCRE_H
|
|
p->init = mod_rewrite_init;
|
|
/* it has to stay _raw as we are matching on uri + querystring
|
|
*/
|
|
|
|
p->handle_uri_raw = mod_rewrite_uri_handler;
|
|
p->handle_physical = mod_rewrite_physical;
|
|
- p->set_defaults = mod_rewrite_set_defaults;
|
|
p->cleanup = mod_rewrite_free;
|
|
p->connection_reset = mod_rewrite_con_reset;
|
|
+#endif
|
|
+ p->set_defaults = mod_rewrite_set_defaults;
|
|
|
|
p->data = NULL;
|
|
|